# TMS320TCI648x Serial RapidIO (SRIO)

# **User's Guide**

Literature Number: SPRUE13A September 2006



| Pref | ace     |                                                                                         | 14 |
|------|---------|-----------------------------------------------------------------------------------------|----|
| 1    | Overvi  | ew                                                                                      | 16 |
|      | 1.1     | General RapidIO System                                                                  | 10 |
|      | 1.2     | RapidIO Feature Support in SRIO                                                         | 1  |
|      | 1.3     | Standards                                                                               | 2( |
|      | 1.4     | External Devices Requirements                                                           | 2( |
|      | 1.5     | TI Devices Supported By This Document                                                   | 2( |
| 2    | SRIO F  | Functional Description                                                                  | 2′ |
|      | 2.1     | Overview                                                                                | 2  |
|      | 2.2     | SRIO Pins                                                                               | 2  |
|      | 2.3     | Functional Operation                                                                    | 26 |
| 3    | Logica  | I/Transport Error Handling and Logging                                                  | 83 |
| 4    | Interru | pt Conditions                                                                           | 8  |
|      | 4.1     | CPU Interrupts                                                                          | 8  |
|      | 4.2     | General Description                                                                     | 8  |
|      | 4.3     | Interrupt Condition Status and Clear Registers                                          | 8  |
|      | 4.4     | Interrupt Condition Routing Registers                                                   | 9: |
|      | 4.5     | Interrupt Status Decode Registers                                                       | 9  |
|      | 4.6     | Interrupt Generation                                                                    | 9  |
|      | 4.7     | Interrupt Pacing                                                                        | 9  |
|      | 4.8     | Interrupt Handling 1                                                                    | 0  |
| 5    | SRIO F  | Registers 1                                                                             | 02 |
|      | 5.1     | Introduction 1                                                                          | 02 |
|      | 5.2     | Peripheral Identification Register (PID) 1                                              | 1  |
|      | 5.3     | Peripheral Control Register (PCR) 1                                                     | 1: |
|      | 5.4     | Peripheral Settings Control Register (PER_SET_CNTL) 1                                   | 1: |
|      | 5.5     | Peripheral Global Enable Register (GBL_EN) 1                                            |    |
|      | 5.6     | Peripheral Global Enable Status Register (GBL_EN_STAT) 1                                | 1  |
|      | 5.7     | Block <i>n</i> Enable Register (BLK <i>n</i> _EN) 1                                     | 19 |
|      | 5.8     | Block <i>n</i> Enable Status Register (BLK <i>n</i> _EN_STAT) 1                         | 2  |
|      | 5.9     | RapidIO DEVICEID1 Register (DEVICEID_REG1) 1                                            | 2  |
|      | 5.10    | RapidIO DEVICEID2 Register (DEVICEID_REG2) 1                                            |    |
|      | 5.11    | Packet Forwarding Register <i>n</i> for 16-Bit Device IDs (PF_16B_CNTL <i>n</i> ) 1     | 2  |
|      | 5.12    | Packet Forwarding Register <i>n</i> for 8-Bit Device IDs (PF_8B_CNTL <i>n</i> ) 1       |    |
|      | 5.13    | SERDES Receive Channel Configuration Register <i>n</i> (SERDES_CFGRX <i>n</i> _CNTL) 1  | 2  |
|      | 5.14    | SERDES Transmit Channel Configuration Register <i>n</i> (SERDES_CFGTX <i>n</i> _CNTL) 1 | 2  |
|      | 5.15    | SERDES Macro Configuration Register n (SERDES_CFGn_CNTL) 1                              | 3( |
|      | 5.16    | DOORBELLn Interrupt Condition Status Register (DOORBELLn_ICSR) 1                        | 32 |
|      | 5.17    | DOORBELLn Interrupt Condition Clear Register (DOORBELLn_ICCR) 1                         | 3  |
|      | 5.18    | RX CPPI Interrupt Status Register (RX_CPPI_ICSR) 1                                      | 3  |
|      | 5.19    | RX CPPI Interrupt Clear Register (RX_CPPI_ICCR) 1                                       | 3  |
|      | 5.20    | TX CPPI Interrupt Status Register (TX_CPPI_ICSR) 1                                      | 36 |
|      | 5.21    | TX CPPI Interrupt Clear Register (TX_CPPI_ICCR) 1                                       |    |
|      | 5.22    | LSU Interrupt Condition Status Register (LSU_ICSR) 1                                    | 38 |

| 5.23 | LSU Interrupt Condition Clear Register (LSU_ICCR)                                                                                     | 141 |
|------|---------------------------------------------------------------------------------------------------------------------------------------|-----|
| 5.24 | Error, Reset, and Special Event Interrupt Condition Status Register<br>(ERR_RST_EVNT_ICSR)                                            | 142 |
| 5.25 | Error, Reset, and Special Event Interrupt Condition Clear Register<br>(ERR_RST_EVNT_ICCR)                                             | 143 |
| 5.26 | DOORBELL <i>n</i> Interrupt Condition Routing Registers (DOORBELL <i>n</i> _ICRR and DOORBELL <i>n</i> _ICRR2)                        | 144 |
| 5.27 | RX CPPI Interrupt Condition Routing Registers (RX_CPPI_ICRR and RX_CPPI_ICRR2)                                                        | 145 |
| 5.28 | TX CPPI Interrupt Condition Routing Registers (TX_CPPI_ICRR and TX_CPPI_ICRR2)                                                        | 146 |
| 5.29 | LSU Interrupt Condition Routing Registers (LSU_ICRR0–LSU_ICRR3)                                                                       | 147 |
| 5.30 | Error, Reset, and Special Event Interrupt Condition Routing Registers (ERR_RST_EVNT_ICRR, ERR_RST_EVNT_ICRR2, and ERR_RST_EVNT_ICRR3) | 149 |
| 5.31 | Interrupt Status Decode Register (INTDSTn_DECODE)                                                                                     |     |
| 5.32 | INTDST <i>n</i> Interrupt Rate Control Register (INTDST <i>n</i> _RATE_CNTL)                                                          | 154 |
| 5.33 | LSUn Control Register 0 (LSUn_REG0)                                                                                                   | 155 |
| 5.34 | LSUn Control Register 1 (LSUn_REG1)                                                                                                   | 156 |
| 5.35 | LSUn Control Register 2 (LSUn_REG2)                                                                                                   | 157 |
| 5.36 | LSUn Control Register 3 (LSUn_REG3)                                                                                                   |     |
| 5.37 | LSUn Control Register 4 (LSUn_REG4)                                                                                                   |     |
| 5.38 | LSUn Control Register 5 (LSUn_REG5)                                                                                                   |     |
| 5.39 | LSUn Control Register 6 (LSUn_REG6)                                                                                                   | 161 |
| 5.40 | LSU <i>n</i> Congestion Control Flow Mask Register (LSU <i>n</i> _FLOW_MASKS)                                                         |     |
| 5.41 | Queue <i>n</i> Transmit DMA Head Descriptor Pointer Register (QUEUE <i>n</i> _TXDMA_HDP)                                              |     |
| 5.42 | Queue <i>n</i> Transmit DMA Completion Pointer Register (QUEUE <i>n</i> _TXDMA_CP)                                                    | 165 |
| 5.43 | Queue <i>n</i> Receive DMA Head Descriptor Pointer Register (QUEUE <i>n</i> _RXDMA_HDP)                                               | 166 |
| 5.44 | Queue <i>n</i> Receive DMA Completion Pointer Register (QUEUE <i>n</i> _RXDMA_CP)                                                     | 167 |
| 5.45 | Transmit Queue Teardown Register (TX_QUEUE_TEAR_DOWN)                                                                                 |     |
| 5.46 | Transmit CPPI Supported Flow Mask Registers (TX_CPPI_FLOW_MASKS[0-7])                                                                 |     |
| 5.47 | Receive Queue Teardown Register (RX_QUEUE_TEAR_DOWN)                                                                                  |     |
| 5.48 | Receive CPPI Control Register (RX_CPPI_CNTL)                                                                                          |     |
| 5.49 | Transmit CPPI Weighted Round Robin Control Registers (TX_QUEUE_CNTL[0-3])                                                             |     |
| 5.50 | Mailbox to Queue Mapping Registers (RXU_MAP_Ln and RXU_MAP_Hn)                                                                        |     |
| 5.51 | Flow Control Table Entry Register n (FLOW_CNTLn)                                                                                      |     |
| 5.52 | Device Identity CAR (DEV_ID)                                                                                                          |     |
| 5.53 | Device Information CAR (DEV_INFO)                                                                                                     |     |
| 5.54 | Assembly Identity CAR (ASBLY_ID)                                                                                                      |     |
| 5.55 | Assembly Information CAR (ASBLY_INFO)                                                                                                 |     |
| 5.56 | Processing Element Features CAR (PE_FEAT)                                                                                             |     |
| 5.57 | Source Operations CAR (SRC_OP)                                                                                                        |     |
| 5.58 | Destination Operations CAR (DEST_OP)                                                                                                  |     |
| 5.59 | Processing Element Logical Layer Control CSR (PE_LL_CTL)                                                                              |     |
| 5.60 | Local Configuration Space Base Address 0 CSR (LCL_CFG_HBAR)                                                                           |     |
| 5.61 | Local Configuration Space Base Address 1 CSR (LCL_CFG_BAR)                                                                            |     |
| 5.62 | Base Device ID CSR (BASE_ID)                                                                                                          |     |
| 5.63 | Host Base Device ID Lock CSR (HOST_BASE_ID_LOCK)                                                                                      |     |
| 5.64 | Component Tag CSR (COMP_TAG)                                                                                                          |     |
| 5.65 | 1x/4x LP Serial Port Maintenance Block Header Register (SP_MB_HEAD)                                                                   |     |
| 5.66 | Port Link Time-Out Control CSR (SP_LT_CTL)                                                                                            |     |
| 5.67 | Port Response Time-Out Control CSR (SP_RT_CTL)                                                                                        |     |
| 5.68 | Port General Control CSR (SP_GEN_CTL)                                                                                                 | 199 |

|       | 5.69 | Port Link Maintenance Request CSR n (SPn_LM_REQ)                                          | 200 |
|-------|------|-------------------------------------------------------------------------------------------|-----|
|       | 5.70 | Port Link Maintenance Response CSR n (SPn_LM_RESP)                                        | 201 |
|       | 5.71 | Port Local AckID Status CSR n (SPn_ACKID_STAT)                                            | 202 |
|       | 5.72 | Port Error and Status CSR n (SPn_ERR_STAT)                                                | 203 |
|       | 5.73 | Port Control CSR n (SPn_CTL)                                                              | 206 |
|       | 5.74 | Error Reporting Block Header Register (ERR_RPT_BH)                                        | 209 |
|       | 5.75 | Logical/Transport Layer Error Detect CSR (ERR_DET)                                        | 210 |
|       | 5.76 | Logical/Transport Layer Error Enable CSR (ERR_EN)                                         | 212 |
|       | 5.77 | Logical/Transport Layer High Address Capture CSR (H_ADDR_CAPT)                            | 214 |
|       | 5.78 | Logical/Transport Layer Address Capture CSR (ADDR_CAPT)                                   | 215 |
|       | 5.79 | Logical/Transport Layer Device ID Capture CSR (ID_CAPT)                                   | 216 |
|       | 5.80 | Logical/Transport Layer Control Capture CSR (CTRL_CAPT)                                   | 217 |
|       | 5.81 | Port-Write Target Device ID CSR (PW_TGT_ID)                                               | 218 |
|       | 5.82 | Port Error Detect CSR <i>n</i> (SP <i>n</i> _ERR_DET)                                     | 219 |
|       | 5.83 | Port Error Rate Enable CSR <i>n</i> (SP <i>n</i> _RATE_EN)                                | 221 |
|       | 5.84 | Port <i>n</i> Attributes Error Capture CSR 0 (SP <i>n</i> _ERR_ATTR_CAPT_DBG0)            | 223 |
|       | 5.85 | Port <i>n</i> Error Capture CSR 1 (SP <i>n</i> _ERR_CAPT_DBG1)                            | 224 |
|       | 5.86 | Port <i>n</i> Error Capture CSR 2 (SP <i>n</i> _ERR_CAPT_DBG2)                            | 225 |
|       | 5.87 | Port <i>n</i> Error Capture CSR 3 (SP <i>n</i> _ERR_CAPT_DBG3)                            | 226 |
|       | 5.88 | Port <i>n</i> Error Capture CSR 4 (SP <i>n</i> _ERR_CAPT_DBG4)                            | 227 |
|       | 5.89 | Port Error Rate CSR <i>n</i> (SP <i>n</i> _ERR_RATE)                                      | 228 |
|       | 5.90 | Port Error Rate Threshold CSR <i>n</i> (SP <i>n</i> _ERR_THRESH)                          | 229 |
|       | 5.91 | Port IP Discovery Timer for 4x Mode Register (SP_IP_DISCOVERY_TIMER)                      | 230 |
|       | 5.92 | Port IP Mode CSR (SP_IP_MODE)                                                             | 231 |
|       | 5.93 | Port IP Prescaler Register (IP_PRESCAL)                                                   | 233 |
|       | 5.94 | Port-Write-In Capture CSRs (SP_IP_PW_IN_CAPT[0–3])                                        | 234 |
|       | 5.95 | Port Reset Option CSR <i>n</i> (SP <i>n</i> _RST_OPT)                                     | 235 |
|       | 5.96 | Port Control Independent Register n (SPn_CTL_INDEP)                                       | 236 |
|       | 5.97 | Port Silence Timer <i>n</i> Register (SP <i>n</i> _SILENCE_TIMER)                         | 238 |
|       | 5.98 | Port Multicast-Event Control Symbol Request Register <i>n</i> (SP <i>n</i> _MULT_EVNT_CS) | 239 |
|       | 5.99 | Port Control Symbol Transmit <i>n</i> Register (SP <i>n</i> _CS_TX)                       | 240 |
| Index |      |                                                                                           | 241 |
|       |      |                                                                                           |     |

### List of Figures

| 1  | RapidIO Architectural Hierarchy                                                                                          | 17 |
|----|--------------------------------------------------------------------------------------------------------------------------|----|
| 2  | RapidIO Interconnect Architecture                                                                                        | 18 |
| 3  | Serial RapidIO Device to Device Interface Diagrams                                                                       | 19 |
| 4  | SRIO Peripheral Block Diagram                                                                                            | 22 |
| 5  | Operation Sequence                                                                                                       | 23 |
| 6  | 1x/4x RapidIO Packet Data Stream (Streaming-Write Class)                                                                 | 24 |
| 7  | Serial RapidIO Control Symbol Format                                                                                     | 24 |
| 8  | SRIO Component Block Diagram                                                                                             | 27 |
| 9  | SERDES Macro Configuration Register 0 (SERDES_CFG0_CNTL)                                                                 | 28 |
| 10 | SERDES Receive Channel Configuration Register n (SERDES_CFGRXn_CNTL)                                                     | 31 |
| 11 | SERDES Transmit Channel Configuration Register <i>n</i> (SERDES_CFGTX <i>n</i> _CNTL)                                    | 33 |
| 12 | Load/Store Registers for RapidIO (Address Offset: LSU1 400h–418h, LSU2 420h–438h, LSU3 440h–458h, LSU4 460h-478h)        | 36 |
| 13 | LSU Registers Timing                                                                                                     | 38 |
| 14 | Example Burst NWRITE_R                                                                                                   | 39 |
| 15 | Load/Store Module Data Flow Diagram                                                                                      | 40 |
| 16 | CPPI RX Scheme for RapidIO                                                                                               | 44 |
| 17 | Message Request Packet                                                                                                   | 45 |
| 18 | Mailbox to Queue Mapping Register Pair                                                                                   | 46 |
| 19 | RX Buffer Descriptor Fields                                                                                              | 47 |
| 20 | RX CPPI Mode Explanation                                                                                                 | 49 |
| 21 | CPPI Boundary Diagram                                                                                                    | 51 |
| 22 | TX Buffer Descriptor Fields                                                                                              | 52 |
| 23 | Weighted Round Robin Programming Registers (Address Offset 7E0h–7ECh)                                                    | 56 |
| 24 | RX Buffer Descriptors                                                                                                    | 62 |
| 25 | TX Buffer Descriptors                                                                                                    | 63 |
| 26 | Doorbell Operation                                                                                                       | 64 |
| 27 | Flow Control Table Entry Registers (Address Offset 0900h–093Ch)                                                          | 66 |
| 28 | Transmit Source Flow Control Masks                                                                                       | 67 |
| 29 | Fields Within Each Flow Mask                                                                                             | 67 |
| 30 | Configuration Bus Example                                                                                                | 69 |
| 31 | DMA Example                                                                                                              | 69 |
| 32 | GBL_EN (Address 0030h)                                                                                                   | 71 |
| 33 | GBL_EN_STAT (Address 0034h)                                                                                              | 71 |
| 34 | BLK0_EN (Address 0038h)                                                                                                  | 72 |
| 35 | BLK0_EN_STAT (Address 003Ch)                                                                                             | 73 |
| 36 | BLK1_EN (Address 0040h)                                                                                                  | 73 |
| 37 | BLK1_EN_STAT (Address 0044h)                                                                                             | 73 |
| 38 | BLK8_EN (Address 0078h)                                                                                                  | 73 |
| 39 | BLK8_EN_STAT (Address 007Ch)                                                                                             | 73 |
| 40 | Peripheral Control Register (PCR) - Address Offset 0004h                                                                 | 74 |
| 41 | Bootload Operation                                                                                                       | 80 |
| 42 | Packet Forwarding Register <i>n</i> for 16-Bit Device IDs (PF_16B_CNTL <i>n</i> ) Offsets 0x0090, 0x0098, 0x00A0, 0x00A8 | 81 |
| 43 | Packet Forwarding Register <i>n</i> for 8-Bit Device IDs (PF_8B_CNTL <i>n</i> ) Offsets 0x0094, 0x009C, 0x00A4, 0x00AC   | 82 |
| 44 | Logical/Transport Layer Error Detect CSR (ERR_DET)                                                                       | 83 |
| 45 | RapidIO DOORBELL Packet for Interrupt Use                                                                                | 85 |
| 46 | Doorbell 0 Interrupt Condition Status and Clear Registers                                                                | 87 |
| 47 | Doorbell 1 Interrupt Condition Status and Clear Registers                                                                | 87 |
| 48 | Doorbell 2 Interrupt Condition Status and Clear Registers                                                                |    |
| 49 | Doorbell 3 Interrupt Condition Status and Clear Registers                                                                | 88 |

| 50       | RX CPPI Interrupt Condition Status and Clear Registers                                              | . 89 |
|----------|-----------------------------------------------------------------------------------------------------|------|
| 51       | TX CPPI Interrupt Condition Status and Clear Registers                                              | . 89 |
| 52       | LSU Interrupt Condition Status and Clear Registers                                                  | . 90 |
| 53       | Error, Reset, and Special Event Interrupt Condition Status and Clear Registers                      | . 91 |
| 54       | Doorbell 0 Interrupt Condition Routing Registers                                                    | . 94 |
| 55       | RX CPPI Interrupt Condition Routing Registers                                                       | . 94 |
| 56       | TX CPPI Interrupt Condition Routing Registers                                                       | . 95 |
| 57       | LSU Interrupt Condition Routing Registers                                                           | . 96 |
| 58       | Error, Reset, and Special Event Interrupt Condition Routing Registers                               | . 97 |
| 59       | Interrupt Status Decode Register (INTDSTn_DECODE)                                                   | . 98 |
| 60       | Interrupt Sources Assigned to ISDR Bits                                                             | . 98 |
| 61       | Example Diagram of Interrupt Status Decode Register Mapping                                         | . 99 |
| 62       | INTDSTn_RATE_CNTL Interrupt Rate Control Register                                                   | 100  |
| 63       | Peripheral ID Register (PID) - Address Offset 0000h                                                 | 111  |
| 64       | Peripheral Control Register (PCR) - Address Offset 0004h                                            | 112  |
| 65       | Peripheral Settings Control Register (PER_SET_CNTL) (Address Offset 0020h)                          | 113  |
| 66       | Peripheral Global Enable Register (GBL_EN) (Address Offset 0030h)                                   |      |
| 67       | Peripheral Global Enable Status Register (GBL_EN_STAT) - Address 0034h                              | 117  |
| 68       | Block <i>n</i> Enable Register (BLK <i>n</i> _EN)                                                   | 119  |
| 69       | Block n Enable Status Register (BLKn_EN)                                                            | 120  |
| 70       | RapidIO DEVICEID1 Register (DEVICEID_REG1) (Offset 0080h)                                           | 121  |
| 71       | RapidIO DEVICEID2 Register (DEVICEID_REG2) (Offset 0x0084)                                          | 122  |
| 72       | Packet Forwarding Register <i>n</i> for 16-Bit Device IDs (PF_16B_CNTL <i>n</i> )                   | 123  |
| 73       | Packet Forwarding Register <i>n</i> for 8-Bit Device IDs (PF_8B_CNTL <i>n</i> )                     | 124  |
| 74       | SERDES Receive Channel Configuration Register <i>n</i> (SERDES_CFGRX <i>n</i> _CNTL)                | 125  |
| 75       | SERDES Transmit Channel Configuration Register <i>n</i> (SERDES_CFGTX <i>n</i> _CNTL)               | 128  |
| 76       | SERDES Macro Configuration Register n (SERDES_CFGn_CNTL)                                            | 130  |
| 77       | Doorbell <i>n</i> Interrupt Condition Status Register (DOORBELL <i>n</i> _ICSR)                     | 132  |
| 78       | Doorbell <i>n</i> Interrupt Condition Clear Register (DOORBELL <i>n</i> _ICCR)                      | 133  |
| 79       | RX CPPI Interrupt Condition Status Register (RX_CPPI_ICSR) - Address Offset 0240h                   | 134  |
| 80       | RX CPPI Interrupt Condition Clear Register (RX_CPPI_ICCR) - Address Offset 0248h                    | 135  |
| 81       | TX CPPI Interrupt Condition Status Register (TX_CPPI_ICSR) - Address Offset 0250h                   | 136  |
| 82       | TX CPPI Interrupt Condition Clear Register (TX_CPPI_ICCR) - Address Offset 0258h                    | 137  |
| 83       | LSU Interrupt Condition Status Register (LSU_ICSR) - Address Offset 0260h                           | 138  |
| 84       | LSU Interrupt Condition Clear Register (LSU_ICCR) - Address Offset 0268h                            | 141  |
| 85       | Error, Reset, and Special Event Interrupt Condition Status Register (ERR_RST_EVNT_ICSR) - Address   |      |
|          | Offset 0270h                                                                                        | 142  |
| 86       | Error, Reset, and Special Event Interrupt Condition Clear Register (ERR_RST_EVNT_ICCR) - Address    | 140  |
| 87       | Offset 0278h<br>Doorbell <i>n</i> Interrupt Condition Routing Registers                             |      |
| 88       |                                                                                                     |      |
| 89       | RX CPPI Interrupt Condition Routing Registers         TX CPPI Interrupt Condition Routing Registers |      |
| 89<br>90 | LSU Interrupt Condition Routing Registers                                                           |      |
| 90<br>91 | Error, Reset, and Special Event Interrupt Condition Routing Registers                               |      |
| 92       | Interrupt Status Decode Register (INTDST <i>n</i> _DECODE)                                          |      |
| 93       | INTDST <i>n</i> Interrupt Rate Control Register (INTDST <i>n</i> _RATE_CNTL)                        |      |
| 94       | LSU <i>n</i> Control Register 0 (LSU <i>n</i> _REG0)                                                |      |
| 95       | LSU <i>n</i> Control Register 0 (LSU <i>n</i> _REG1)                                                |      |
| 95<br>96 | LSU <i>n</i> Control Register 7 (LSU <i>n</i> _REG2)                                                |      |
| 90<br>97 | LSU <i>n</i> Control Register 2 (LSU <i>n</i> _REG2)                                                |      |
| 98       | LSU <i>n</i> Control Register 3 (LSU <i>n</i> _REG3)                                                |      |
| 99       | LSU <i>n</i> Control Register 5 (LSU <i>n</i> _REG5)                                                |      |
| 100      | LSU <i>n</i> Control Register 6 (LSU <i>n</i> _REG6)                                                |      |
| 101      | LSU <i>n</i> Congestion Control Flow Mask Register (LSU <i>n</i> _FLOW_MASKS)                       |      |
|          | J                                                                                                   |      |

| 102 | LSU <i>n</i> FLOW_MASK Fields                                                                | 162 |
|-----|----------------------------------------------------------------------------------------------|-----|
| 103 | Queue <i>n</i> Transmit DMA Head Descriptor Pointer Register (QUEUE <i>n</i> _TXDMA_HDP)     | 164 |
| 104 | Queue <i>n</i> Transmit DMA Completion Pointer Register (QUEUE <i>n</i> _TXDMA_CP)           | 165 |
| 105 | Queue <i>n</i> Receive DMA Head Descriptor Pointer Register (QUEUE <i>n</i> _RXDMA_HDP)      | 166 |
| 106 | Queue <i>n</i> Receive DMA Completion Pointer Register (QUEUE <i>n</i> _RXDMA_CP)            | 167 |
| 107 | Transmit Queue Teardown Register (TX_QUEUE_TEAR_DOWN) - Address Offset 0700h                 | 168 |
| 108 | Transmit CPPI Supported Flow Mask Registers                                                  | 170 |
| 109 | TX Queue <i>n</i> FLOW_MASK Fields                                                           | 170 |
| 110 | Receive Queue Teardown Register (RX_QUEUE_TEAR_DOWN) (Address Offset 0740h)                  | 172 |
| 111 | Receive CPPI Control Register (RX_CPPI_CNTL) (Address Offset 0744h)                          | 173 |
| 112 | Transmit CPPI Weighted Round Robin Control Registers                                         | 174 |
| 113 | Mailbox to Queue Mapping Register Pair                                                       |     |
| 114 | Flow Control Table Entry Register <i>n</i> (FLOW_CNTL <i>n</i> )                             | 181 |
| 115 | Device Identity CAR (DEV_ID) - Address Offset 1000h                                          | 182 |
| 116 | Device Information CAR (DEV_INFO) - Address Offset 1004h                                     | 183 |
| 117 | Assembly Identity CAR (ASBLY_ID) - Address Offset 1008h                                      |     |
| 118 | Assembly Information CAR (ASBLY_INFO) - Address Offset 100Ch                                 |     |
| 119 | Processing Element Features CAR (PE_FEAT) - Address Offset 1010h                             |     |
| 120 | Source Operations CAR (SRC_OP) - Address Offset 1018h                                        |     |
| 121 | Destination Operations CAR (DEST_OP) - Address Offset 101Ch                                  |     |
| 122 | Processing Element Logical Layer Control CSR (PE_LL_CTL) - Address Offset 104Ch              |     |
| 123 | Local Configuration Space Base Address 0 CSR (LCL_CFG_HBAR) - Address Offset 1058h           | 191 |
| 124 | Local Configuration Space Base Address 1 CSR (LCL_CFG_BAR) - Address Offset 105Ch            | 192 |
| 125 | Base Device ID CSR (BASE_ID) - Address Offset 1060h                                          | 193 |
| 126 | Host Base Device ID Lock CSR (HOST_BASE_ID_LOCK) - Address Offset 1068h                      |     |
| 127 | Component Tag CSR (COMP_TAG) - Address Offset 106Ch                                          | 195 |
| 128 | 1x/4x LP_Serial Port Maintenance Block Header Register (SP_MB_HEAD) - Address Offset 1100h   |     |
| 129 | Port Link Time-Out Control CSR (SP_LT_CTL) - Address Offset 1120h                            |     |
| 130 | Port Response Time-Out Control CSR (SP_RT_CTL) - Address Offset 1124h                        |     |
| 131 | Port General Control CSR (SP_GEN_CTL) - Address Offset 113Ch                                 |     |
| 132 | Port Link Maintenance Request CSR n (SPn_LM_REQ)                                             | 200 |
| 133 | Port Link Maintenance Response CSR n (SPn_LM_RESP)                                           | 201 |
| 134 | Port Local AckID Status CSR n (SPn_ACKID_STAT)                                               | 202 |
| 135 | Port Error and Status CSR n (SPn_ERR_STAT)                                                   | 203 |
| 136 | Port Control CSR n (SPn_CTL)                                                                 | 206 |
| 137 | Error Reporting Block Header Register (ERR_RPT_BH) - Address Offset 2000h                    | 209 |
| 138 | Logical/Transport Layer Error Detect CSR (ERR_DET) - Address Offset 2008h                    | 210 |
| 139 | Logical/Transport Layer Error Enable CSR (ERR_EN) - Address Offset 200Ch                     | 212 |
| 140 | Logical/Transport Layer High Address Capture CSR (H_ADDR_CAPT) - Address Offset 2010h        | 214 |
| 141 | Logical/Transport Layer Address Capture CSR (ADDR_CAPT) - Address Offset 2014h               | 215 |
| 142 | Logical/Transport Layer Device ID Capture CSR (ID_CAPT) - Address Offset 2018h               | 216 |
| 143 | Logical/Transport Layer Control Capture CSR (CTRL_CAPT) - Address Offset 201Ch               | 217 |
| 144 | Port-Write Target Device ID CSR (PW_TGT_ID) - Address Offset 2028h                           | 218 |
| 145 | Port Error Detect CSR n (SPn_ERR_DET)                                                        |     |
| 146 | Port Error Rate Enable CSR <i>n</i> (SP <i>n</i> _RATE_EN)                                   | 221 |
| 147 | Port <i>n</i> Attributes Error Capture CSR 0 (SP <i>n</i> _ERR_ATTR_CAPT_DBG0)               | 223 |
| 148 | Port <i>n</i> Error Capture CSR 1 (SP <i>n</i> _ERR_CAPT_DBG1)                               |     |
| 149 | Port <i>n</i> Error Capture CSR 2 (SP <i>n</i> _ERR_CAPT_DBG2)                               |     |
| 150 | Port <i>n</i> Error Capture CSR 3 (SP <i>n</i> _ERR_CAPT_DBG3)                               |     |
| 151 | Port <i>n</i> Error Capture CSR 4 (SP <i>n</i> _ERR_CAPT_DBG4)                               |     |
| 152 | Port Error Rate CSR n (SPn_ERR_RATE)                                                         |     |
| 153 | Port Error Rate Threshold CSR n (SPn_ERR_THRESH)                                             | 229 |
| 154 | Port IP Discovery Timer for 4x Mode Register (SP_IP_DISCOVERY_TIMER) - Address Offset 12000h | 230 |

| 155 | Port IP Mode CSR (SP_IP_MODE) - Address Offset 12004h                     | 231 |
|-----|---------------------------------------------------------------------------|-----|
| 156 | Port IP Prescaler Register (IP_PRESCAL) - Address Offset 12008h           | 233 |
| 157 | Port-Write-In Capture CSRs                                                | 234 |
| 158 | Port Reset Option CSR n (SPn_RST_OPT)                                     | 235 |
| 159 | Port Control Independent Register n (SPn_CTL_INDEP)                       | 236 |
| 160 | Port Silence Timer <i>n</i> Register (SP <i>n</i> _SILENCE_TIMER)         | 238 |
| 161 | Port Multicast-Event Control Symbol Request Register n (SPn_MULT_EVNT_CS) | 239 |
| 162 | Port Control Symbol Transmit <i>n</i> Register (SP <i>n</i> _CS_TX)       | 240 |

#### List of Tables

| 1  | TI Devices Supported By This Document                                                                    | 20  |
|----|----------------------------------------------------------------------------------------------------------|-----|
| 2  | Registers Checked for Multicast DeviceID                                                                 | 21  |
| 3  | Packet Types                                                                                             | 25  |
| 4  | Pin Description                                                                                          | 26  |
| 5  | SERDES Macro Configuration Register 0 (SERDES_CFG0_CNTL) Field Descriptions                              | 29  |
| 6  | Line Rate versus PLL Output Clock Frequency                                                              | 30  |
| 7  | Effect of the RATE Bits                                                                                  | 30  |
| 8  | Frequency Range versus MPY Value                                                                         | 30  |
| 9  | SERDES Receive Channel Configuration Register <i>n</i> (SERDES_CFGRX <i>n</i> _CNTL) Field Descriptions  | 31  |
| 10 | EQ Bits                                                                                                  | 33  |
| 11 | SERDES Transmit Channel Configuration Register <i>n</i> (SERDES_CFGTX <i>n</i> _CNTL) Field Descriptions | 33  |
| 12 | DE Bits of SERDES_CFGTXn_CNTL                                                                            | 34  |
| 13 | SWING Bits of SERDES_CFGTXn_CNTL                                                                         | 35  |
| 14 | LSU Control/Command Register Fields                                                                      | 36  |
| 15 | LSU Status Register Fields                                                                               | 37  |
| 16 | RX DMA State Head Descriptor Pointer (HDP) (Address Offset 600h–63Ch)                                    | 46  |
| 17 | RX DMA State Completion Pointer (CP) (Address Offset 680h–6BCh)                                          | 46  |
| 18 | RX Buffer Descriptor Field Descriptions                                                                  | 47  |
| 19 | TX DMA State Head Descriptor Pointer (HDP) (Address Offset 500h–53Ch)                                    | 51  |
| 20 | TX DMA State Completion Pointer (CP) (Address Offset 58h–5BCh)                                           | 52  |
| 21 | TX Buffer Descriptor Field Definitions                                                                   | 52  |
| 22 | Weighted Round Robin Programming Registers (Address Offset 7E0h–7ECh)                                    | 56  |
| 23 | Examples of DOORBELL_INFO Designations (See Figure 26 )                                                  | 64  |
| 24 | Flow Control Table Entry Register <i>n</i> (FLOW_CNTL <i>n</i> ) Field Descriptions                      | 67  |
| 25 | Fields Within Each Flow Mask                                                                             | 68  |
| 26 | Reset Hierarchy                                                                                          | 70  |
| 27 | Global Enable and Global Enable Status Field Descriptions                                                | 72  |
| 28 | Block Enable and Block Enable Status Field Descriptions                                                  |     |
| 29 | Peripheral Control Register (PCR) Field Descriptions                                                     |     |
| 30 | Port Mode Register Settings                                                                              |     |
| 31 | Multicast DeviceID Operation                                                                             | 81  |
| 32 | Packet Forwarding Register <i>n</i> for 16-Bit DeviceIDs (PF_16B_CNTL <i>n</i> ) Field Descriptions      |     |
| 33 | Packet Forwarding Register <i>n</i> for 8-Bit DeviceIDs (PF_8B_CNTL <i>n</i> ) Field Descriptions        |     |
| 34 | Logical/Transport Layer Error Detect CSR (ERR_DET) Field Descriptions                                    |     |
| 35 | Interrupt Condition Status and Clear Bits                                                                |     |
| 36 | Interrupt Conditions Shown in LSU_ICSR and Cleared With LSU_ICCR                                         |     |
| 37 | Interrupt Conditions Shown in ERR_RST_EVNT_ICSR and Cleared With ERR_RST_EVNT_ICCR                       |     |
| 38 | Interrupt Clearing Sequence for Special Event Interrupts                                                 |     |
| 39 | Interrupt Condition Routing Options                                                                      |     |
| 40 | Serial RapidIO (SRIO) Registers                                                                          |     |
| 41 | Peripheral ID Register (PID) Field Descriptions                                                          |     |
| 42 | Peripheral Control Register (PCR) Field Descriptions                                                     |     |
| 43 | Peripheral Settings Control Register (PER_SET_CNTL) Field Descriptions                                   |     |
| 44 | Peripheral Global Enable Register (GBL_EN) Field Descriptions                                            |     |
| 45 | Peripheral Global Enable Status Register (GBL_EN_STAT) Field Descriptions                                |     |
| 46 | Block <i>n</i> Enable Registers and the Associated Blocks                                                |     |
| 47 | Block <i>n</i> Enable Register (BLK <i>n</i> _EN) Field Descriptions                                     |     |
| 48 | Block <i>n</i> Enable Status Registers and the Associated Blocks                                         |     |
| 49 | Block <i>n</i> Enable Status Register (BLK <i>n</i> _EN_STAT) Field Descriptions                         | 120 |

| 50                                                                                                 | RapidIO DEVICEID1 Register (DEVICEID_REG1) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 121                                                                                                                 |
|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| 50<br>51                                                                                           | RapidIO DEVICEID2 Register (DEVICEID_REG2) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                     |
| 52                                                                                                 | PF_16B_CNTL Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                     |
| 53                                                                                                 | Packet Forwarding Register <i>n</i> for 16-Bit DeviceIDs (PF_16B_CNTL <i>n</i> ) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                     |
| 53<br>54                                                                                           | PF_8B_CNTL Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                     |
|                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                     |
| 55                                                                                                 | Packet Forwarding Register <i>n</i> for 8-Bit DeviceIDs (PF_8B_CNTL <i>n</i> ) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                     |
| 56                                                                                                 | SERDES_CFGRX <i>n</i> _CNTL Registers and the Associated Ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                     |
| 57                                                                                                 | SERDES Receive Channel Configuration Register <i>n</i> (SERDES_CFGRX <i>n</i> _CNTL) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                     |
| 58                                                                                                 | EQ Bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                     |
| 59                                                                                                 | SERDES_CFGTXn_CNTL Registers and the Associated Ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                     |
| 60                                                                                                 | SERDES Transmit Channel Configuration Register <i>n</i> (SERDES_CFGTX <i>n</i> _CNTL) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                     |
| 61                                                                                                 | DE Bits of SERDES_CFGTXn_CNTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                     |
| 62                                                                                                 | SWING Bits of SERDES_CFGTXn_CNTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                     |
| 63                                                                                                 | SERDES_CFGn_CNTL Registers and the Associated Ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 130                                                                                                                 |
| 64                                                                                                 | SERDES Macro Configuration Register <i>n</i> (SERDES_CFG <i>n</i> _CNTL) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 130                                                                                                                 |
| 65                                                                                                 | DOORBELLn_ICSR Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 132                                                                                                                 |
| 66                                                                                                 | DOORBELLn Interrupt Condition Status Register (DOORBELLn_ICSR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 132                                                                                                                 |
| 67                                                                                                 | DOORBELLn_ICCR Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 133                                                                                                                 |
| 68                                                                                                 | DOORBELL <i>n</i> Interrupt Condition Clear Register (DOORBELL <i>n</i> _ICCR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 133                                                                                                                 |
| 69                                                                                                 | RX CPPI Interrupt Condition Status Register (RX_CPPI_ICSR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                     |
| 70                                                                                                 | RX CPPI Interrupt Condition Clear Register (RX_CPPI_ICCR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                     |
| 71                                                                                                 | TX CPPI Interrupt Condition Status Register (TX_CPPI_ICSR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                     |
| 72                                                                                                 | TX CPPI Interrupt Condition Clear Register (TX_CPPI_ICCR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                     |
| 73                                                                                                 | LSU Interrupt Condition Status Register (LSU_ICSR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                     |
| 74                                                                                                 | LSU Interrupt Condition Clear Register (LSU_ICCR) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                     |
| 75                                                                                                 | Error, Reset, and Special Event Interrupt Condition Status Register (ERR_RST_EVNT_ICSR) Field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                     |
| 10                                                                                                 | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 142                                                                                                                 |
| 76                                                                                                 | Error, Reset, and Special Event Interrupt Condition Clear Register (ERR_RST_EVNT_ICCR) Field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                     |
|                                                                                                    | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 143                                                                                                                 |
| 77                                                                                                 | DOORBELLn_ICRR Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 144                                                                                                                 |
| 78                                                                                                 | DOORBELLn Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 144                                                                                                                 |
|                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                     |
| 79                                                                                                 | RX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 145                                                                                                                 |
| 79<br>80                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                     |
|                                                                                                    | RX CPPI Interrupt Condition Routing Register Field Descriptions         TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 146                                                                                                                 |
| 80                                                                                                 | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148                                                                                                          |
| 80<br>81                                                                                           | TX CPPI Interrupt Condition Routing Register Field Descriptions<br>LSU Interrupt Condition Routing Register Field Descriptions<br>Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 146<br>148<br>149                                                                                                   |
| 80<br>81<br>82<br>83                                                                               | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 146<br>148<br>149<br>150                                                                                            |
| 80<br>81<br>82<br>83<br>84                                                                         | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                              | 146<br>148<br>149<br>150<br>150                                                                                     |
| 80<br>81<br>82<br>83<br>84<br>85                                                                   | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations                                                                                                                                                                                                                                                                                                                | 146<br>148<br>149<br>150<br>150<br>154                                                                              |
| 80<br>81<br>82<br>83<br>84<br>85<br>86                                                             | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn Interrupt Rate Control Register (INTDSTn_RATE_CNTL) Field Descriptions                                                                                                                                                                                                                         | 146<br>148<br>149<br>150<br>150<br>154<br>154                                                                       |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87                                                       | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn Interrupt Rate Control Register (INTDSTn_RATE_CNTL) Field Descriptions         LSUn_REG0 Registers and the Associated LSUs         | 146<br>148<br>149<br>150<br>150<br>154<br>154<br>155                                                                |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88                                                 | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn Interrupt Rate Control Register (INTDSTn_RATE_CNTL) Field Descriptions         LSUn_REG0 Registers and the Associated LSUs         LSUn Control Register 0 (LSUn_REG0) Field Descriptions                                                                                                      | 146<br>148<br>149<br>150<br>150<br>154<br>154<br>155<br>155                                                         |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>88<br>89                                     | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn Interrupt Rate Control Register (INTDSTn_RATE_CNTL) Field Descriptions         LSUn_REG0 Registers and the Associated LSUs         LSUn_REG1 Register 0 (LSUn_REG0) Field Descriptions                                                                                                         | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>155                                                         |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90                                     | TX CPPI Interrupt Condition Routing Register Field Descriptions         LSU Interrupt Condition Routing Register Field Descriptions         Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions         INTDSTn_DECODE Registers and the Associated Interrupt Destinations         Interrupt Status Decode Register (INTDSTn_DECODE) Field Descriptions         INTDSTn_RATE_CNTL Registers and the Associated Interrupt Destinations         INTDSTn Interrupt Rate Control Register (INTDSTn_RATE_CNTL) Field Descriptions         LSUn_REG0 Registers and the Associated LSUs         LSUn_REG1 Registers and the Associated LSUs         LSUn_REG1 Registers and the Associated LSUs         LSUn_REG1 Register 1 (LSUn_REG1) Field Descriptions | 146<br>148<br>150<br>150<br>154<br>154<br>155<br>155<br>156<br>156                                                  |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91                               | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>155<br>156<br>156<br>157                                    |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92                         | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>155<br>156<br>156<br>157                                    |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93                   | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>156<br>156<br>157<br>157<br>158                             |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93<br>94             | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>156<br>156<br>157<br>157<br>158<br>158                      |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93<br>94<br>95       | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>156<br>156<br>157<br>157<br>158<br>158<br>158               |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93<br>94<br>95<br>96 | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>154<br>155<br>155<br>155<br>156<br>157<br>157<br>158<br>158<br>159<br>159               |
| 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93<br>94<br>95       | TX CPPI Interrupt Condition Routing Register Field Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 146<br>148<br>149<br>150<br>150<br>154<br>155<br>155<br>155<br>156<br>157<br>157<br>157<br>158<br>159<br>159<br>160 |

| 99  | LSUn_REG6 Registers and the Associated LSUs                                                                 |     |
|-----|-------------------------------------------------------------------------------------------------------------|-----|
| 100 | LSUn Control Register 6 (LSUn_REG6) Field Descriptions                                                      |     |
| 101 | LSUn_FLOW_MASKS Registers and the Associated LSUs                                                           | 162 |
| 102 | LSUn Congestion Control Flow Mask Register (LSUn_FLOW_MASKS) Field Descriptions                             | 162 |
| 103 | LSU <i>n</i> FLOW_MASK Fields                                                                               | 162 |
| 104 | QUEUEn_TXDMA_HDP Registers                                                                                  | 164 |
| 105 | Queue <i>n</i> Transmit DMA Head Descriptor Pointer Register (QUEUE <i>n</i> _TXDMA_HDP) Field Descriptions | 164 |
| 106 | QUEUEn_TXDMA_CP Registers                                                                                   |     |
| 107 | Queue Transmit DMA Completion Pointer Registers (QUEUEn_TXDMA_CP) Field Descriptions                        | 165 |
| 108 | QUEUEn_RXDMA_HDP Registers                                                                                  | 166 |
| 109 | Queue <i>n</i> Receive DMA Head Descriptor Pointer Register (QUEUE <i>n</i> _RXDMA_HDP) Field Descriptions  | 166 |
| 110 | QUEUEn_RXDMA_CP Registers                                                                                   | 167 |
| 111 | Queue <i>n</i> Receive DMA Completion Pointer Register (QUEUE <i>n</i> _RXDMA_CP) Field Descriptions        | 167 |
| 112 | Transmit Queue Teardown Register (TX_QUEUE_TEAR_DOWN) Field Descriptions                                    | 168 |
| 113 | TX_CPPI_FLOW_MASKS Registers and the Associated TX Queues                                                   |     |
| 114 | TX Queue <i>n</i> FLOW_MASK Field Descriptions                                                              | 170 |
| 115 | Receive Queue Teardown Register (RX_QUEUE_TEAR_DOWN) Field Descriptions                                     | 172 |
| 116 | Receive CPPI Control Register (RX_CPPI_CNTL) Field Descriptions                                             | 173 |
| 117 | Transmit CPPI Weighted Round Robin Control Register Field Descriptions                                      | 175 |
| 118 | Mailbox to Queue Mapping Registers and the Associated RX Mappers                                            | 177 |
| 119 | Mailbox-to-Queue Mapping Register Ln (RXU_MAP_Ln) Field Descriptions                                        | 179 |
| 120 | Mailbox-to-Queue Mapping Register Hn (RXU_MAP_Hn) Field Descriptions                                        |     |
| 121 | FLOW_CNTLn Registers                                                                                        | 181 |
| 122 | Flow Control Table Entry Register <i>n</i> (FLOW_CNTL <i>n</i> ) Field Descriptions                         |     |
| 123 | Device Identity CAR (DEV_ID) Field Descriptions                                                             |     |
| 124 | Device Information CAR (DEV_INFO) Field Descriptions                                                        | 183 |
| 125 | Assembly Identity CAR (ASBLY_ID) Field Descriptions                                                         |     |
| 126 | Assembly Information CAR (ASBLY_INFO) Field Descriptions                                                    | 185 |
| 127 | Processing Element Features CAR (PE_FEAT) Field Descriptions                                                |     |
| 128 | Source Operations CAR (SRC_OP) Field Descriptions                                                           | 188 |
| 129 | Destination Operations CAR (DEST_OP) Field Descriptions                                                     |     |
| 130 | Processing Element Logical Layer Control CSR (PE_LL_CTL) Field Descriptions                                 | 190 |
| 131 | Local Configuration Space Base Address 0 CSR (LCL_CFG_HBAR) Field Descriptions                              |     |
| 132 | Local Configuration Space Base Address 1 CSR (LCL_CFG_BAR) Field Descriptions                               |     |
| 133 | Base Device ID CSR (BASE_ID) Field Descriptions                                                             | 193 |
| 134 | Host Base Device ID Lock CSR (HOST_BASE_ID_LOCK) Field Descriptions                                         |     |
| 135 | Component Tag CSR (COMP_TAG) Field Descriptions                                                             |     |
| 136 | 1x/4x LP_Serial Port Maintenance Block Header Register (SP_MB_HEAD) Field Descriptions                      | 196 |
| 137 | Port Link Timeout Control CSR (SP_LT_CTL) Field Descriptions                                                |     |
| 138 | Port Response Time-Out Control CSR (SP_RT_CTL) Field Descriptions                                           |     |
| 139 | Port General Control CSR (SP_GEN_CTL) Field Descriptions                                                    |     |
| 140 | SPn_LM_REQ Registers and the Associated Ports                                                               | 200 |
| 141 | Port Link Maintenance Request CSR n (SPn_LM_REQ) Field Descriptions                                         | 200 |
| 142 | SPn_LM_RESP Registers and the Associated Ports                                                              | 201 |
| 143 | Port Link Maintenance Response CSR n (SPn_LM_RESP) Field Descriptions                                       |     |
| 144 | SPn_ACKID_STAT Registers and the Associated Ports                                                           |     |
| 145 | Port Local AckID Status CSR n (SPn_ACKID_STAT) Field Descriptions                                           | 202 |
| 146 | SPn_ERR_STAT Registers and the Associated Ports                                                             |     |
| 147 | Port Error and Status CSR n (SPn_ERR_STAT) Field Descriptions                                               |     |
| 148 | SPn_CTL Registers and the Associated Ports                                                                  |     |
| 149 | Port Control CSR n (SPn_CTL) Field Descriptions                                                             | 206 |

| 150 | Error Reporting Block Header Register (ERR_RPT_BH) Field Descriptions                             | 209 |
|-----|---------------------------------------------------------------------------------------------------|-----|
| 151 | Logical/Transport Layer Error Detect CSR (ERR_DET) Field Descriptions                             | 210 |
| 152 | Logical/Transport Layer Error Enable CSR (ERR_EN) Field Descriptions                              | 212 |
| 153 | Logical/Transport Layer High Address Capture CSR (H_ADDR_CAPT) Field Descriptions                 | 214 |
| 154 | Logical/Transport Layer Address Capture CSR (ADDR_CAPT) Field Descriptions                        | 215 |
| 155 | Logical/Transport Layer Device ID Capture CSR (ID_CAPT) Field Descriptions                        | 216 |
| 156 | Logical/Transport Layer Control Capture CSR (CTRL_CAPT) Field Descriptions                        | 217 |
| 157 | Port-Write Target Device ID CSR (PW_TGT_ID) Field Descriptions                                    | 218 |
| 158 | SPn_ERR_DET Registers and the Associated Ports                                                    | 219 |
| 159 | Port Error Detect CSR n (SPn_ERR_DET) Field Descriptions                                          | 219 |
| 160 | SPn_RATE_EN Registers and the Associated Ports                                                    |     |
| 161 | Port Error Rate Enable CSR <i>n</i> (SP <i>n</i> _RATE_EN) Field Descriptions                     | 221 |
| 162 | SPn_ERR_ATTR_CAPT_DBG0 Registers and the Associated Ports                                         | 223 |
| 163 | Port <i>n</i> Attributes Error Capture CSR 0 (SP <i>n</i> _ERR_ATTR_CAPT_DBG0) Field Descriptions | 223 |
| 164 | SPn_ERR_CAPT_DBG1 Registers and the Associated Ports                                              | 224 |
| 165 | Port <i>n</i> Error Capture CSR 1 (SP <i>n</i> _ERR_CAPT_DBG1) Field Descriptions                 | 224 |
| 166 | SPn_ERR_CAPT_DBG2 Registers and the Associated Ports                                              | 225 |
| 167 | Port <i>n</i> Error Capture CSR 2 (SP <i>n</i> _ERR_CAPT_DBG2) Field Descriptions                 | 225 |
| 168 | SPn_ERR_CAPT_DBG3 Registers and the Associated Ports                                              | 226 |
| 169 | Port <i>n</i> Error Capture CSR 3 (SP <i>n</i> _ERR_CAPT_DBG3) Field Descriptions                 | 226 |
| 170 | SPn_ERR_CAPT_DBG4 Registers and the Associated Ports                                              | 227 |
| 171 | Port <i>n</i> Error Capture CSR 4 (SP <i>n</i> _ERR_CAPT_DBG4) Field Descriptions                 | 227 |
| 172 | SPn_ERR_RATE Registers and the Associated Ports                                                   | 228 |
| 173 | Port Error Rate CSR n (SPn_ERR_RATE) Field Descriptions                                           | 228 |
| 174 | SPn_ERR_THRESH Registers and the Associated Ports                                                 | 229 |
| 175 | Port Error Rate Threshold CSR <i>n</i> (SP <i>n</i> _ERR_THRESH) Field Descriptions               | 229 |
| 176 | Port IP Discovery Timer for 4x Mode Register (SP_IP_DISCOVERY_TIMER) Field Descriptions           | 230 |
| 177 | Port IP Mode CSR (SP_IP_MODE) Field Descriptions                                                  | 231 |
| 178 | Port IP Prescaler Register (IP_PRESCAL) Field Descriptions                                        | 233 |
| 179 | Port-Write-In Capture CSR Field Descriptions                                                      | 234 |
| 180 | SPn_RST_OPT Registers and the Associated Ports                                                    | 235 |
| 181 | Port Reset Option CSR <i>n</i> (SP <i>n</i> _RST_OPT) Field Descriptions                          | 235 |
| 182 | SPn_CTL_INDEP Registers and the Associated Ports                                                  | 236 |
| 183 | Port Control Independent Register <i>n</i> (SP <i>n</i> _CTL_INDEP) Field Descriptions            | 236 |
| 184 | SPn_SILENCE_TIMER Registers and the Associated Ports                                              | 238 |
| 185 | Port Silence Timer <i>n</i> Register (SP <i>n</i> _SILENCE_TIMER) Field Descriptions              | 238 |
| 186 | SPn_MULT_EVNT_CS Registers and the Associated Ports                                               | 239 |
| 187 | Port Multicast-Event Control Symbol Request Register n (SPn_MULT_EVNT_CS) Field Descriptions      | 239 |
| 188 | SPn_CS_TX Registers and the Associated Ports                                                      | 240 |
| 189 | Port Control Symbol Transmit <i>n</i> Register (SP <i>n</i> _CS_TX) Field Descriptions            | 240 |



#### About This Manual

This document describes the Serial RapidIO<sup>®</sup> (SRIO) peripheral on the TMS320TCI648x<sup>™</sup> devices.

#### **Notational Conventions**

This document uses the following conventions.

- Hexadecimal numbers are shown with the suffix h. For example, the following number represents 40 hexadecimal (decimal 64): 40h.
- Registers in this document are shown in figures and described in tables.
  - Each register figure shows a rectangle divided into fields that represent the fields of the register.
     Each field is labeled with its bit name, its beginning and ending bit numbers above, and its read/write properties below. A legend explains the notation used for the properties.
  - Reserved bits in a register figure designate a bit that is used for future device expansion.

#### **Related Documentation From Texas Instruments**

The following documents describe the C6000<sup>™</sup> devices and related support tools. Copies of these documents are available on the Internet at www.ti.com. *Tip:* Enter the literature number in the search box provided at <u>www.ti.com</u>.

*Implementing Serial RapidIO (SRIO) PCB Layout on a TMS320TCI6482 Hardware Design* (literature number <u>SPRAAB0</u>) specifies a complete printed circuit board (PCB) solution for the TCI6482 as well as a list of compatible SRIO devices showing two DSPs connected via a 4x SRIO link. TI has performed the simulation and system characterization to ensure all SRIO interface timings in this solution are met; therefore, no electrical data/timing information is supplied here for this interface.

**TMS320C6000 CPU and Instruction Set Reference Guide** (literature number <u>SPRU189</u>) gives an introduction to the TMS320C62x<sup>™</sup> and TMS320C67x<sup>™</sup> DSPs, development tools, and third-party support.

**TMS320C6000 Programmer's Guide** (literature number <u>SPRU198</u>) describes ways to optimize C and assembly code for the TMS320C6000<sup>™</sup> DSPs and includes application program examples.

*TMS320C6000 Code Composer Studio Tutorial* (literature number <u>SPRU301</u>) introduces the Code Composer Studio<sup>™</sup> integrated development environment and software tools.

**Code Composer Studio Application Programming Interface Reference Guide** (literature number <u>SPRU321</u>) describes the Code Composer Studio<sup>™</sup> application programming interface (API), which allows you to program custom plug-ins for Code Composer.

*TMS320C64x+ Megamodule Reference Guide* (literature number <u>SPRU871</u>) describes the TMS320C64x+ digital signal processor (DSP) megamodule. Included is a discussion on the internal direct memory access (IDMA) controller, the interrupt controller, the power-down controller, memory protection, bandwidth management, and the memory and cache.

**TMS320TCI648x Bootloader User's Guide**(literature number <u>SPRUEC7</u>) describes the features of the on-chip Bootloader provided with the TMS320TCI648x Digital Signal Processor (DSP). Included are descriptions of the available boot modes and any interfacing requirements associated with them, instructions on generating the boot table, and information on the different versions of the Bootloader.

14



#### Trademarks

TMS320TCI648x, C6000, TMS320C62x, TMS320C67x, TMS320C6000, Code Composer Studio are trademarks of Texas Instruments.

RapidIO is a registered trademark of RapidIO Trade Association.

InfiniBand is a trademark of the InfiniBand Trade Association.



### Serial RapidIO (SRIO)

#### 1 Overview

The RapidIO peripheral used in the TMS320TCI648x is called a serial RapidIO (SRIO). This chapter describes the general operation of a RapidIO system, how this module is connected to the outside world, the definitions of terms used within this document, and the features supported and not supported for SRIO.

#### 1.1 General RapidIO System

RapidIO<sup>®</sup> is a non-proprietary high-bandwidth system level interconnect. It is a packet-switched interconnect intended primarily as an intra-system interface for chip-to-chip and board-to-board communications at Gigabyte-per-second performance levels. Uses for the architecture can be found in connected microprocessors, memory, and memory mapped I/O devices that operate in networking equipment, memory subsystems, and general purpose computing. Principle features of RapidIO include:

- Flexible system architecture allowing peer-to-peer communication
- Robust communication with error detection features
- · Frequency and port width scalability
- Operation that is not software intensive
- High bandwidth interconnect with low overhead
- Low pin count
- Low power
- Low latency

#### 1.1.1 RapidIO Architectural Hierarchy

RapidIO is defined as a 3-layer architectural hierarchy.

- Logical layer: Specifies the protocols, including packet formats, which are needed by endpoints to process transactions
- Transport layer: Defines addressing schemes to correctly route information packets within a system
- **Physical layer:** Contains the device level interface information such as the electrical characteristics, error management data, and basic flow control data

In the RapidIO architecture, a single specification for the transport layer is compatible with differing specifications for the logical and physical layers (see Figure 1).



Figure 1. RapidIO Architectural Hierarchy



#### 1.1.2 RapidIO Interconnect Architecture

The interconnect architecture is defined as a packet switched protocol independent of a physical layer implementation. Figure 2 illustrates the interconnection system.



Figure 2. RapidIO Interconnect Architecture

(1) InfiniBand<sup>™</sup> is a trademark of the InfiniBand Trade Association.

#### 1.1.3 Physical Layer 1x/4x LP-Serial Specification

Currently, there are two physical layer specifications recognized by the RapidIO Trade Association: 8/16 LP-LVDS and 1x/4x LP-Serial. The 8/16 LP-LVDS specification is a point-to-point synchronous clock sourcing DDR interface. The 1x/4x LP-Serial specification is a point-to-point, AC coupled, clock recovery interface. The two physical layer specifications are not compatible.

SRIO complies with the 1x/4x LP-Serial specification. The serializer/deserializer (SERDES) technology in SRIO also aligns with that specification.

The RapidIO *Physical Layer 1x/4x LP-Serial Specification* currently covers three frequency points: 1.25, 2.5, and 3.125 Gbps. This defines the total bandwidth of each differential pair of I/O signals. An 8-bit/10-bit encoding scheme ensures ample data transitions for the clock recovery circuits. Due to the 8-bit/10-bit encoding overhead, the effective data bandwidth per differential pair is 1.0, 2.0, and 2.5 Gbps respectively. Serial RapidIO only specifies these rates for both the 1x and 4x ports. A 1x port is defined as 1 TX and 1 RX differential pair. A 4x port is a combination of four of these pairs. This document describes a 4x RapidIO port that can also be configured as four 1x ports, thus providing a scalable interface capable of supporting a data bandwidth of 1 to 10 Gbps.

Figure 3 shows how to interface two 1x devices and two 4x devices. Each *positive* transmit data line (TDx) on one device is connected to a *positive* receive data line (RDx) on the other device. Likewise, each *negative* transmit data line (TDx) is connected to a *negative* receive data line (RDx).





#### Figure 3. Serial RapidIO Device to Device Interface Diagrams



#### 1.2 RapidIO Feature Support in SRIO

#### Features Supported in SRIO Peripheral:

- RapidIO Interconnect Specification V1.2 compliance, Errata 1.2
- Physical Layer 1x/4x LP-Serial Specification V1.2 compliance
- 4x Serial RapidIO with auto-negotiation to 1x port, optional operation for four 1x ports
- Integrated clock recovery with TI SERDES
- Hardware error handling including Cyclic Redundancy Code (CRC)
- Differential CML signaling supporting AC coupling
- Support for 1.25, 2.5, and 3.125 Gbps rates
- Power-down option for unused ports
- Read, write, write with response, streaming write, outgoing Atomic, and maintenance operations
- Generates interrupts to the CPU (Doorbell packets and internal scheduling)
- Support for 8-bit and 16-bit device ID
- Support for receiving 34-bit addresses
- Support for generating 34-bit, 50-bit, and 66-bit addresses
- Support for the following data sizes: byte, half-word, word, double-word
- Big endian data transfers
- Direct I/O transfers
- Message passing transfers
- Data payloads of up to 256 bytes
- Single messages consisting of up to 16 packets
- Elastic storage FIFOs for clock domain handoff
- Short run and long run compliance
- Support for Error Management Extensions
- Support for Congestion Control Extensions
- Support for one multi-cast ID



#### **Features Not Supported:**

- Compliance with the Global Shared Memory specification (GSM)
- 8/16 LP-LVDS compatible
- Destination support of RapidIO Atomic Operations
- Simultaneous mixing of frequencies between 1x ports (all ports must be the same frequency)
- Target atomic operations (including increment, decrement, test-and-swap, set, and clear) for internal L2 memory and registers

#### 1.3 Standards

The SRIO peripheral is compliant to V1.2 of the *RapidIO Interconnect Specification* and V1.2 of the RapidIO *Physical Layer 1x/4x LP-Serial Specification*. These and the various associated documents listed herein can be found at the official RapidIO website: www.RapidIO.org.

#### 1.4 External Devices Requirements

SRIO provides a seamless interface to all devices which are compliant to V1.2 of the RapidIO *Physical Layer 1x/4x LP-Serial Specification*. This includes ASIC, microprocessor, DSP, and switch fabric devices from multiple vendors. Compliance to the specification can be verified with bus-functional models available through the RapidIO Trade Association, as well as test suites currently available for licensing.

#### 1.5 TI Devices Supported By This Document

| Device        | Number of<br>DSP Cores (CPUs) | Number of<br>Ports | Number of<br>Lanes | Configurations | SRIO Module<br>Frequency |
|---------------|-------------------------------|--------------------|--------------------|----------------|--------------------------|
| TMS320TCI6482 | 1                             | 4                  | 4                  | 1x/4x, 1x/1x   | DSP frequency ÷ 4        |

#### Table 1. TI Devices Supported By This Document



#### 2 SRIO Functional Description

#### 2.1 Overview

#### 2.1.1 Peripheral Data Flow

This peripheral is designed to be an externally driven slave module that is capable of acting as a master in the DSP system. This means that an external device can push (burst write) data to the DSP as needed, without having to generate an interrupt to the CPU or without relying on the DSP EDMA. This has several benefits. It cuts down on the total number of interrupts, it reduces handshaking (latency) associated with read-only peripherals, and it frees up the EDMA for other tasks.

SRIO specifies data packets with payloads up to 256 bytes. Many times, transactions will span across multiple packets. RapidIO specifies a maximum of 16 transactions per message. Although a request is generated for each packet transaction so that the DMA can transfer the data to L2 memory, an interrupt is only generated after the final packet of the message. This interrupt notifies the CPU that data is available in L2 Memory for processing.

As an endpoint device, the peripheral accepts packets based on the destination ID. Two options exist for packet acceptance and are mode selectable. The first option is to only accept packets whose DestIDs match the local deviceID in 0x0080. This provides a level of security. The second option is is system multicast operation. When multicast is enabled in SP\_IP\_MODE (offset 12004h) bit 5, incoming packets matching the deviceID in the registers shown in are accepted.

|               | Registers Checked For Multicast DeviceID |                |  |  |  |  |
|---------------|------------------------------------------|----------------|--|--|--|--|
| Device        | Name                                     | Address Offset |  |  |  |  |
| TMS320TCI6482 | Local DeviceID Register                  | 0080h          |  |  |  |  |
|               | Multicast DeviceID Register              | 0084h          |  |  |  |  |

#### Table 2. Registers Checked for Multicast DeviceID

Data flow through the peripheral can be explained using the high-level block diagram shown in Figure 4. High-speed data enters from the device pins into the RX block of the SERDES macro. The RX block is a differential receiver expecting a minimum of 175mV peak-to-peak differential input voltage (Vid). Level shifting is performed in the RX block, such that the output is single ended CMOS. The serial data is then fed to the SERDES clock recovery block. The sole purpose of this block is to extract a clock signal from the data stream. To do this, a low-frequency reference clock is required. Typically, this clock comes from an off-chip stable crystal oscillator and is a LVDS device input separate to the SERDES. This clock is distributed to the SERDES PLL block which multiplies that frequency up to that of the data rate. Multiple high-speed clock phases are created and routed to the clock recovery blocks. The clock recovery blocks further interpolate between these clocks to provide maximum Unit Interval (UI) resolution on the recovered clock. The clock recovery block samples the incoming data and monitors the relative positions of the data edges. With this information, it can provide the data and a center-aligned clock to the S2P block. The S2P block uses the newly recovered clock to de-multiplex the data into 10-bit words. At this point, the data leaves the SERDES macro at 1/10th the pin data rate, accompanied by an aligned byte clock.





Figure 4. SRIO Peripheral Block Diagram

Within the physical layer, the data next goes to the 8-bit/10-bit (8b/10b) decode block. 8b/10b encoding is used by RapidIO to ensure adequate data transitions for the clock recovery circuits. Here the 20% encoding overhead is removed as the 10-bit data is decoded to the raw 8-bit data. At this point, the recovered byte clock is still being used.

The next step is clock synchronization and data alignment. These functions are handled by the FIFO and lane de-skewing blocks. In the *RapidIO Interconnect Specification*, a "lane" is one serial differential pair. The FIFO provides an elastic store mechanism used to hand off between the recovered clock domains and a common system clock. After the FIFO, the four lanes are synchronized in frequency and phase, whether 1X or 4X mode is being used. The FIFO is 8 words deep. The lane de-skew is only meaningful in the 4X mode, where it aligns each channel's word boundaries, such that the resulting 32-bit word is correctly aligned.

The CRC error detection block keeps a running tally of the incoming data and computes the expected CRC value for the 1X or 4X mode. The expected value is compared against the CRC value at the end of the received packet.

After the packet reaches the logical layer, the packet fields are decoded and the payload is buffered. Depending on the type of received packet, the packet routing is handled by functional blocks which control the DMA access.

#### 2.1.2 SRIO Packets

The SRIO data stream consists of data fields pertaining to the logical layer, the transport layer, and the physical layer.

- The logical layer consists of the header (defining the type of access) and the payload (if present).
- The transport layer is partially dependent on the physical topology in the system, and consists of source and destination IDs for the sending and receiving devices.
- The physical layer is dependent on the physical interface (i.e., serial versus parallel RapidIO) and includes priority, acknowledgment, and error checking fields.

#### 2.1.2.1 Operation Sequence

SRIO transactions are based on request and response packets. Packets are the communication element between endpoint devices in the system. A master or initiator generates a request packet which is transmitted to a target. The target then generates a response packet back to the initiator to complete the transaction.

SRIO endpoints are typically not connected directly to each other but instead have intervening connection fabric devices. Control symbols are used to manage the flow of transactions in the SRIO physical interconnect. Control symbols are used for packet acknowledgment, flow control information, and maintenance functions. Figure 5 shows how a packet progresses through the system.



Figure 5. Operation Sequence

#### 2.1.2.2 Example Packet – Streaming Write

An example packet is shown as two data streams in Figure 6. The first is for payload sizes of 80 bytes or less, while the second applies to payload sizes of 80 to 256 bytes. SRIO packets must have a length that is an even integer of 32 bits. If the combination of physical, logical and transport layers has a length that is an integer of 16 bits, a 16-bit pad of value 0000h is added to the end of the packet, after the CRC (not shown). Bit fields that are defined as reserved are assigned to logic 0s when generated and ignored when received. All request and response packet formats are described in the RapidIO *Input/Output Logical Specification* and *Mlessage Passing Logical Specification*.





**Note:** Figure 6 assumes that addresses are 32-bit and device IDs are 8-bit.

The device ID, being an 8-bit field, will address up to 256 nodes in the system. If 16-bit addresses were used, the system could accommodate up to 64k nodes.

The data stream includes a Cyclic Redundancy Code (CRC) field to ensure the data was correctly received. The CRC value protects the entire packet except the ackID and one bit of the reserved PHY field. The peripheral checks the CRC automatically in hardware. If the CRC is correct, a Packet-Accepted control symbol is sent by the receiving device. If the CRC is incorrect, a Packet-Not-Accepted control symbol is sent so that transmission may be retried.

#### 2.1.2.3 Control Symbols

Control symbols are physical layer message elements used to manage link maintenance, packet delimiting, packet acknowledgment, error reporting, and error recovery. All transmitted data packets are delimited by start-of-packet and end-of-packet delimiters. SRIO control symbols are 24 bits long and are protected by their own CRC (see Figure 7). Control symbols provide two functions: stype0 symbols convey the status of the port transmitting the symbol, and stype1 symbols are requests to the receiving port or transmission delimiters. They have the following format, which is detailed in Section 3 of the RapidIO *Physical Layer 1x/4x LP-Serial Specification*.

| Delimiter | 1st E  | Byte       | 2nd I      | Byte   | 3rd Byte |     |  |
|-----------|--------|------------|------------|--------|----------|-----|--|
| SC or PD  | stype0 | Parameter0 | parameter1 | stype1 | cmd      | CRC |  |
| 8         | 3      | 5          | 5          | 3      | 3        | 5   |  |

#### Figure 7. Serial RapidIO Control Symbol Format

Control symbols are delimited by special characters at the beginning of the symbol. If the control symbol contains a packet delimiter(start-of-packet, end-of-packet, etc.), the special character PD (K28.3) is used. If the control symbol does not contain a packet delimiter, the special character SC (K28.0) is used. This use of special characters provides an early warning of the contents of the control symbol. The CRC does not protect the special characters, but an illegal or invalid character is recognized and flagged as Packet-Not-Accepted. Since control symbols are known length, they do not need end delimiters.

The type of received packet determines how the packet routing is handled. Reserved or undefined packet types are destroyed before being processed by the logical layer functional blocks. This prevents erroneous allocation of resources to them. Unsupported packet types are responded to with an error response packet. Section 2.1.2.4 details the handling of such packets.

#### 2.1.2.4 SRIO Packet Type

The type of SRIO packet is determined by the combination of Ftype and Ttype fields in the packet. Table 3 lists all supported combinations of Ftype/Ttype and the corresponding decoded actions on the packets.

| Ftype      | Ttype              | Packet Type                |  |  |  |
|------------|--------------------|----------------------------|--|--|--|
| Ftype = 0  | Ttype = don't care |                            |  |  |  |
| Ftype = 2  | Ttype = 0100b      | NREAD                      |  |  |  |
|            | Ttype = 1100b      | Atomic increment           |  |  |  |
|            | Ttype = 1101b      | Atomic decrement           |  |  |  |
|            | Ttype = 1110b      | Atomic set                 |  |  |  |
|            | Ttype = 1111b      | Atomic clear               |  |  |  |
|            | Ttype = others     |                            |  |  |  |
| Ftype = 5  | Ttype = 0100b      | NWRITE                     |  |  |  |
|            | Ttype = 0101b      | NWRITE_R                   |  |  |  |
|            | Ttype = 1110b      | Atomic test and swap       |  |  |  |
|            | Ttype = others     |                            |  |  |  |
| Ftype = 6  | Ttype = don't care | SWRITE                     |  |  |  |
| Ftype = 7  | Ttype = don't care | Congestion control         |  |  |  |
| Ftype = 8  | Ttype = 0000b      | Maintenance read           |  |  |  |
|            | Ttype = 0001b      | Maintenance write          |  |  |  |
|            | Ttype = 0010b      | Maintenance read response  |  |  |  |
|            | Ttype = 0011b      | Maintenance write response |  |  |  |
|            | Ttype = 0100b      | Maintenance port-write     |  |  |  |
|            | Ttype = others     |                            |  |  |  |
| Ftype = 10 | Ttype = don't care | Doorbell                   |  |  |  |
| Ftype = 11 | Ttype = don't care | Message                    |  |  |  |
| Ftype = 13 | Ttype = 0000b      | Response(+Doorbell Resp)   |  |  |  |
|            | Ttype = 0001b      | Message Response           |  |  |  |
|            | Ttype = 1000b      | Response w/payload         |  |  |  |
|            | Ttype = other      |                            |  |  |  |

#### Table 3. Packet Types

#### 2.2 SRIO Pins

The SRIO device pins are high-speed differential signals based on Current-Mode Logic (CML) switching levels. The transmit and receive buffers are self-contained within the clock recovery blocks. The reference clock input is not incorporated into the SERDES macro. It uses a differential input buffer that is compatible with the LVDS and LVPECL interfaces available from crystal oscillator manufacturers. Table 4 describes the device pins for the SRIO peripheral.



#### SRIO Functional Description

| Pin Name       | Pin<br>Count | Signal<br>Direction | Description                                                                                                                                                                                    |
|----------------|--------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RIOTX3/ RIOTX3 | 2            | Output              | Transmit Data – Differential point-to-point unidirectional bus. Transmits packet data to a receiving device's RX pins. Most significant bits in 1 port 4X device. Used in 4 port 1X device.    |
| RIOTX2/ RIOTX2 | 2            | Output              | Transmit Data – Differential point-to-point unidirectional bus. Transmits packet data to a receiving device's RX pins. Bit used in 4 port 1x device and 1 port 4X device.                      |
| RIOTX1/ RIOTX1 | 2            | Output              | Transmit Data – Differential point-to-point unidirectional bus. Transmits packet data to a receiving device's RX pins. Bit used in 4 port 1x device and 1 port 4X device.                      |
| RIOTX0/ RIOTX0 | 2            | Output              | Transmit Data – Differential point-to-point unidirectional bus. Transmits packet data to a receiving device's RX pins. Bit used in 1 port 1X device, 4 port 1x device, and 1 port 4X device.   |
| RIORX3/ RIORX3 | 2            | Input               | Receive Data – Differential point-to-point unidirectional bus. Receives packet data for a transmitting device's TX pins. Most significant bits in 1 port 4X device. Used in 4 port 1X device.  |
| RIORX2/ RIORX2 | 2            | Input               | Receive Data – Differential point-to-point unidirectional bus. Receives packet data for a transmitting device's TX pins. Bit used in 4 port 1x device and 1 port 4X device.                    |
| RIORX1/ RIORX1 | 2            | Input               | Receive Data – Differential point-to-point unidirectional bus. Receives packet data for a transmitting device's TX pins. Bit used in 4 port 1x device and 1 port 4X device.                    |
| RIORX0/ RIORX0 | 2            | Input               | Receive Data – Differential point-to-point unidirectional bus. Receives packet data for a transmitting device's TX pins. Bit used in 1 port 1X device, 4 port 1x device, and 1 port 4X device. |
| RIOCLK/ RIOCLK | 2            | Input               | Reference Clock Input Buffer for peripheral clock recovery circuitry.                                                                                                                          |

#### Table 4. Pin Description

#### 2.3 Functional Operation

#### 2.3.1 Component Block Diagram

Figure 8 shows a component block diagram of the SRIO peripheral. The load/store unit (LSU) controls the transmission of direct I/O packets, and the memory access unit (MAU) controls the reception of direct I/O packets. The LSU also controls the transmission of maintenance packets. Message packets are transmitted by the TXU and received by the RXU. These four units use the internal DMA to communicate with internal memory, and they use buffers and receive/transmit ports to communicate with external devices. Serializer/deserializer (SERDES) macros support the ports by performing the parallel-to-serial coding for transmission and serial-to-parallel decoding for reception.





#### 2.3.2 SERDES Macro and its Configurations

SRIO offers many benefits to customers by allowing a scalable non-proprietary interface. With the use of TI's SERDES macros, the peripheral is very adaptable and bandwidth scalable. The same peripheral can be used for all three frequency nodes specified in V1.2 of the *RapidIO Interconnect Specification* (1.25, 2.5, and 3.125 Gbps). This allows you to design to only one protocol throughout the system and selectively choose the bandwidth, thus eliminating the need for user's proprietary protocols in many instances, and providing a faster design turn and production ramp. Since this interface is serial, the application space is not limited to a single board. It will propagate into backplane applications as well. Integration of these macros on an ASIC or DSP allows you to reduce the number of discrete components on the board and eliminates the need for bus driver chips.

Additionally, there are some valuable features built into TI SERDES. System optimization can be uniquely managed to meet individual customer applications. For example, control registers within the SERDES allow you to adjust the TX differential output voltage (Vod) on a per driver basis. This allows power savings on short trace links (on the same board) by reducing the TX swing. Similarly, data edge rates can be adjusted through the control registers to help reduce any EMI affects. Unused links can be individually powered down without affecting the working links.

The SERDES macro is a self-contained macro which includes transmitter (TX), receiver (RX), phase-locked-loop (PLL), clock recovery, serial-to-parallel (S2P), and parallel-to-serial (P2S) blocks. The internal PLL multiplies a user-supplied reference clock. All loop filter components of the PLL are onchip. Likewise, the differential TX and RX buffers contain on-chip termination resistors. The only off-chip component requirement is for DC blocking capacitors.

#### 2.3.2.1 Enabling the PLL

The Physical layer SERDES has a built-in PLL, which is used for the clock recovery circuitry. The PLL is responsible for clock multiplication of a slow speed reference clock. This reference clock has no timing relationship to the serial data and is asynchronous to any CPU system clock. The multiplied high-speed clock is only routed within the SERDES block; it is not distributed to the remaining blocks of the peripheral, nor is it a boundary signal to the core of the device. It is extremely important to have a good quality reference clock, and to isolate it and the PLL from all noise sources. Since RapidIO requires 8-bit/10-bit encoded data, the 8-bit mode of the SERDES PLL is not be used.

The SERDES macro is configured with the register SERDES\_CFG0\_CNTL, SERDES\_CFGRX*n*\_CNTL, and SERDES\_CFGTX*n*\_CNTL, where *n* is the number of the macro. To enable the internal PLL, the ENPLL bit of SERDES\_CFG0\_CNTL (see Figure 9 and Table 5) must be set. After setting this bit, it is necessary to allow 1µs for the regulator to stabilize. Thereafter, the PLL will take no longer than 200 reference clock cycles to lock to the required frequency, provided RIOCLK and RIOCLK are stable.

Registers SERDES\_CFG1\_CNTL, SERDES\_CFG2\_CNTL, and SERDES\_CFG3\_CNTL are not used.

| 31       |       |          |       | 16    |  |  |
|----------|-------|----------|-------|-------|--|--|
|          | R     | eserved  |       |       |  |  |
| R-0000h  |       |          |       |       |  |  |
| 15       | 10 9  | 8 7 6 5  |       | 1 0   |  |  |
| Reserved | LB    | Reserved | MPY   | ENPLL |  |  |
| R-00h    | R/W-0 | R-0      | R/W-0 | R/W-0 |  |  |
|          |       |          |       |       |  |  |

#### Figure 9. SERDES Macro Configuration Register 0 (SERDES\_CFG0\_CNTL)

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 5. SERDES Macro Configuration Register 0 (SERDES\_CFG0\_CNTL) Field Descriptions

| Bit   | Field    | Value  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–10 | Reserved | 0000h  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9–8   | LB       |        | Loop bandwidth. Specify loop bandwidth settings. Jitter on the reference clock will degrade both the transmit eye and receiver jitter tolerance thereby impairing system performance. Performance of the integrated PLL can be optimized according to the jitter characteristics of the reference clock via the LB field.                                                                                                                                                                                                                                                            |
|       |          | 00b    | Frequency dependent bandwidth. The PLL bandwidth is set to a twelfth of the frequency of RIOCLK/RIOCLK. This setting is suitable for most systems that input the reference clock via a low jitter input cell, and is required for standards compliance                                                                                                                                                                                                                                                                                                                               |
|       |          | 01b    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 10b    | Low bandwidth. The PLL bandwidth is set to a twentieth of the frequency of RIOCLK/RIOCLK, or 3MHz (whichever is larger). In systems where the reference clock is directly input via a low jitter input cell, but is of lower quality, this setting may offer better performance. It will reduce the amount of reference clock jitter transferred through the PLL. However, it also increases the susceptibility to loop noise generated within the PLL itself. It is difficult to predict whether the improvement in the former will more than offset the degradation in the latter. |
|       |          | 11b    | High bandwidth. The PLL bandwidth is set to a eighth of the frequency of RIOCLK/RIOCLK. This is the setting appropriate for systems where the reference clock is cleaned through an ultra low jitter LC-based PLL. Standards compliance will be achieved even if the reference clock input to the cleaner PLL is outside the specification for the standard.                                                                                                                                                                                                                         |
| 7–6   | Reserved | 00h    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5–1   | MPY      |        | PLL multiply. Select PLL multiply factors between 4 and 60.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       |          | 00000b | 4x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |          | 00001b | 5x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |          | 00010b | 6x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |          | 00011b | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 00100b | 8x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |          | 00101b | 10x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 00110b | 12x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 00111b | 12.5x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |          | 01000b | 15x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 01001b | 20x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 01010b | 25x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |          | 01011b | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 01100b | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 01111b | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 1xxxxb | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0     | ENPLL    |        | Enable PLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |          | 0      | PLL disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|       |          | 1      | PLL enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Based on the MPY value, the line rate versus PLL output clock frequency can be calculated. This is summarized in Table 6.

| Rate                                | Line Rate | PLL Output Frequency | RATESCALE |
|-------------------------------------|-----------|----------------------|-----------|
| Full                                | x Gbps    | 0.5x GHz             | 0.5       |
| Half                                | x Gbps    | x GHz                | 1         |
| Quarter                             | x Gbps    | 2x GHz               | 2         |
| RIOCLK and RIOCLK <sub>FREQ</sub> = | LINERA    | TE×RATESCALE         |           |
|                                     |           | MPY                  |           |

Table 6. Line Rate versus PLL Output Clock Frequency

The rate is defined by the RATE bits of the SERDES\_CFGRX*n*\_CNTL register and the SERDES\_CFGTX*n*\_CNTL register, respectively.

The primary operating frequency of the SERDES macro is determined by the reference clock frequency and PLL multiplication factor. However, to support lower frequency applications, each receiver and transmitter can also be configured to operate at a half or quarter of this rate via the RATE bits of the SERDES\_CFGRX*n*\_CNTL and SERDES\_CFGTX*n*\_CNTL registers as described in Table 7.

| Table 7. Lifect of the NATE Dits |                                                                        |   |  |  |  |
|----------------------------------|------------------------------------------------------------------------|---|--|--|--|
| RATE                             | Description                                                            | - |  |  |  |
| 00b                              | Full rate. Two data samples taken per PLL output clock cycle.          | - |  |  |  |
| 01b                              | Half rate. One data sample taken per PLL output clock cycle.           |   |  |  |  |
| 10b                              | Quarter rate. One data sample taken every two PLL output clock cycles. |   |  |  |  |
| 11b                              | Reserved.                                                              |   |  |  |  |

#### Table 7. Effect of the RATE Bits

 Table 8 shows the frequency range versus the multiplication factor (MPY).

|       | <b>RIOCLK and RIOCLK</b> |          | Line Rate Range (G | ibps)        |
|-------|--------------------------|----------|--------------------|--------------|
| MPY   | Range (MHz)              | Full     | Half               | Quarter      |
| 4x    | 250 - 425                | 2 - 3.4  | 1 - 1.7            | 0.5 - 0.85   |
| 5x    | 200 - 425                | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 6x    | 167 - 354.167            | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 8x    | 125 - 265.625            | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 10x   | 100 - 212.5              | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 12x   | 83.33 - 177.08           | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 12.5x | 80 - 170                 | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 15x   | 66.67 - 141.67           | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 20x   | 50 - 106.25              | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |
| 25x   | 40 - 85                  | 2 - 4.25 | 1 - 2.125          | 0.5 - 1.0625 |

#### Table 8. Frequency Range versus MPY Value

#### 2.3.2.2 Enabling the Receiver

To enable a receiver for deserialization, the ENRX bit of the associated SERDES\_CFGRX*n*\_CNTL registers (100h–10Ch) must be set high. The fields of SERDES\_CFGRX*n*\_CNTL are shown in Figure 10 and described in Table 9.

When ENRX is low, all digital circuitry within the receiver will be disabled, and clocks will be gated off. All current sources within the receiver will be fully powered down, with the exception of those associated with the loss of signal detector and IEEE1149.6 boundary scan comparators. Loss of signal power down is independently controlled via the LOS bits of SERDES\_CFGRX*n*\_CNTL. When enabled, the differential signal amplitude of the received signal is monitored. Whenever loss of signal is detected, the clock recovery algorithm is frozen to prevent the phase and frequency of the recovered clock from being modified by low level signal noise.

The clock recovery algorithms listed in the CDR bits operate to adjust the clocks used to sample the received message so that the data samples are taken midway between data transitions. The second order algorithm can be optionally disabled, and both can be configured to optimize their dynamics. Both algorithms use the same basic technique for determining whether the sampling clock is ideally placed, and if not whether it needs to be moved earlier or later. When two contiguous data samples are different, the phase sample between the two is examined. Eight data samples and nine phase samples are taken with each result counted as a vote to move the sample point either earlier or later. These eight data bits constitute the voting window. The eight votes are then counted, and an action to adjust the position of the sampling clock occurs if there is a majority of early or late votes. The first order algorithm makes a single phase adjustment per majority vote. The second order algorithm acts repeatedly according to the net difference between early and late majority votes, thereby adjusting for the rate of change of phase.

Setting the ALIGN field to 01 enables alignment to the K28 comma symbols included in the 8b:10b data encoding scheme defined by the IEEE and employed by numerous transmission standards. For systems which cannot use comma based symbol alignment, the single bit alignment jog capability provides a means to control the symbol realignment features of the receiver directly from logic implemented in the ASIC core. This logic can be designed to support whatever alignment detection protocol is required.

The EQ bits allow for enabling and configuring the adaptive equalizer incorporated in all of the receive channels, which can compensate for channel insertion loss by attenuating the low frequency components with respect to the high frequency components of the signal, thereby reducing inter-symbol interference. Above the zero frequency, the gain increases at 6dB/octave until it reaches the high frequency gain. When enabled, the receiver equalization logic analyzes data patterns and transition times to determine whether the low frequency gain of the equalizer should be increased or decreased. For the fully adaptive setting (EQ = 0001), if the low frequency gain reaches the minimum value, the zero frequency is then reduced. Likewise, if it reaches the maximum value, the zero frequency is then increased. This decision logic is implemented as a voting algorithm with a relatively long analysis interval. The slow time constant that results reduces the probability of incorrect decisions but allows the equalizer to compensate for the relatively stable response of the channel.

- No adaptive equalization. The equalizer provides a flat response at the maximum gain. This setting
  may be appropriate if jitter at the receiver occurs predominantly as a result of crosstalk rather than
  frequency dependent loss.
- Fully adaptive equalization. Both the low frequency gain and zero position of the equalizer are determined algorithmically by analysing the data patterns and transition positions in the received data. This setting should be used for most applications.
- Partially adaptive equalisation. The low frequency gain of the equalizer is determined algorithmically by analysing the data patterns and transition positions in the received data. The zero position is fixed in one of eight zero positions. For any given application, the optimal setting is a function of the loss characteristics of the channel and the spectral density of the signal as well as the data rate, which means it is not possible to identify the best setting by data rate alone, although generally speaking, the lower the line rate, the lower the zero frequency that will be required.

| 31    |    |    |         |    |     |    | 26 | 25             |                | 24  | 23    | 22 |       |   |      | 19       | 18 |           | 16    |
|-------|----|----|---------|----|-----|----|----|----------------|----------------|-----|-------|----|-------|---|------|----------|----|-----------|-------|
|       |    |    | Reserve | ed |     |    |    |                | erved<br>e 0s) |     | —     |    |       |   | EQ   |          |    | CDR       |       |
|       |    |    | R-0     |    |     |    |    | R/\            | N-0            |     | R-0   |    |       | R | /W-0 |          |    | R/W-0     |       |
| 15    | 14 | 13 |         | 12 | 11  | 10 |    |                | 8              |     | 7     | 6  |       | 5 | 4    |          | 2  | 1         | 0     |
| LOS   |    |    | ALIGN   |    | _   |    |    | ERM<br>e 001b) |                | IN\ | /PAIR |    | RATE  |   |      | BUSWIDTH |    | (write 0) | ENRX  |
| R/W-0 |    |    | R/W-0   |    | R-0 |    | R  | /W-0           |                | R   | /W-0  |    | R/W-0 |   |      | R/W-0    |    | R/W-0     | R/W-0 |

#### Figure 10. SERDES Receive Channel Configuration Register *n* (SERDES\_CFGRX*n*\_CNTL)

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 9. SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL) Field Descriptions

| Bit   | Field    | Value   | Description                               |  |
|-------|----------|---------|-------------------------------------------|--|
| 31–26 | Reserved | 000000b | These read-only bits return 0s when read. |  |

# Table 9. SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL) Field Descriptions (continued)

| Bit   | Field    | Value       | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25–24 | Reserved | 00b         | Always write 0s to these reserved bits.                                                                                                                                                                                                                                                                                                                                                      |
| 23    | Reserved | 0           | This read-only bit returns 0 when read.                                                                                                                                                                                                                                                                                                                                                      |
| 22–19 | EQ       | 0000b-1111b | Equalizer. Enables and configures the adaptive equalizer to compensate for loss in the transmission media. For the selectable values, see Table 10.                                                                                                                                                                                                                                          |
| 18–16 | CDR      |             | Clock/data recovery. Configures the clock/data recovery algorithm.                                                                                                                                                                                                                                                                                                                           |
|       |          | 000b        | First order. Phase offset tracking up to ±488 ppm.                                                                                                                                                                                                                                                                                                                                           |
|       |          | 001b        | Second order. Highest precision frequency offset matching but poorest response to changes in frequency offset, and longest lock time. Suitable for use in systems with fixed frequency offset.                                                                                                                                                                                               |
|       |          | 010b        | Second order. Medium precision frequency offset matching, frequency offset change response, and lock time.                                                                                                                                                                                                                                                                                   |
|       |          | 011b        | Second order. Best response to changes in frequency offset and fastest lock time, but lowest precision frequency offset matching. Suitable for use in systems with spread spectrum clocking.                                                                                                                                                                                                 |
|       |          | 100b        | First order with fast lock. Phase offset tracking up to $\pm$ 1953 ppm in the presence of10101010 training pattern, and $\pm$ 448 ppm otherwise.                                                                                                                                                                                                                                             |
|       |          | 101b        | Second order with fast lock. As per setting 001, but with improved response to changes in frequency offset when not close to lock.                                                                                                                                                                                                                                                           |
|       |          | 110b        | Second order with fast lock. As per setting 010, but with improved response to changes in frequency offset when not close to lock.                                                                                                                                                                                                                                                           |
|       |          | 111b        | Second order with fast lock. As per setting 011, but with improved response to changes in frequency offset when not close to lock.                                                                                                                                                                                                                                                           |
| 15–14 | LOS      |             | Loss of signal. Enables loss of signal detection with 2 selectable thresholds.                                                                                                                                                                                                                                                                                                               |
|       |          | 00b         | Disabled. Loss of signal detection disabled.                                                                                                                                                                                                                                                                                                                                                 |
|       |          | 01b         | High threshold. Loss of signal detection threshold in the range 85 to $195 mV_{dfpp}.$ This setting is suitable for Infiniband.                                                                                                                                                                                                                                                              |
|       |          | 10b         | Low threshold. Loss of signal detection threshold in the range 65 to $175 mV_{dfpp}.$ This setting is suitable for PCI-E and S-ATA.                                                                                                                                                                                                                                                          |
|       |          | 11b         | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| 13–12 | ALIGN    |             | Symbol alignment. Enables internal or external symbol alignment.                                                                                                                                                                                                                                                                                                                             |
|       |          | 00b         | Alignment disabled. No symbol alignment will be performed while this setting is selected, or when switching to this selection from another.                                                                                                                                                                                                                                                  |
|       |          | 01b         | Comma alignment enabled. Symbol alignment will be performed whenever a misaligned comma symbol is received.                                                                                                                                                                                                                                                                                  |
|       |          | 10b         | Alignment jog. The symbol alignment will be adjusted by one bit position when this mode is selected (that is, the ALIGN value changes from 0xb to 1xb).                                                                                                                                                                                                                                      |
|       |          | 11b         | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| 11    | Reserved | 0           | This read-only bit returns 0 when read.                                                                                                                                                                                                                                                                                                                                                      |
| 10–8  | TERM     | 001Ь        | Input termination. The only valid value for this field is 001b; all other values are reserved. The value 001b sets the common point to 0.8 VDDT and supports AC coupled systems using CML transmitters. The transmitter has no effect on the receiver common mode, which is set to optimize the input sensitivity of the receiver. Common mode termination is via a 50 pF capacitor to VSSA. |
| 7     | INVPAIR  |             | Invert polarity. Inverts polarity of RIORXn and RIORXn.                                                                                                                                                                                                                                                                                                                                      |
|       |          | 0           | Normal polarity. RIORXn is considered to be positive data and RIORXn negative.                                                                                                                                                                                                                                                                                                               |
|       |          | 1           | Inverted polarity. RIORXn is considered to be negative data and RIORXn positive.                                                                                                                                                                                                                                                                                                             |
| 6–5   | RATE     |             | Operating rate. Selects full, half, or quarter rate operation.                                                                                                                                                                                                                                                                                                                               |
|       |          | 00b         | Full rate. Two data samples taken per PLL output clock cycle.                                                                                                                                                                                                                                                                                                                                |
|       |          | 01b         | Half rate. One data sample taken per PLL output clock cycle.                                                                                                                                                                                                                                                                                                                                 |
|       |          | 10b         | Quarter rate. One data sample taken every two PLL output clock cycles.                                                                                                                                                                                                                                                                                                                       |
|       |          | 11b         | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |

|     |          |       | Descriptions (continued)                                                                                                                                                           |
|-----|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Field    | Value | Description                                                                                                                                                                        |
| 4–2 | BUSWIDTH | 000b  | Bus width. Always write 000b to this field, to indicate a 10-bit-wide parallel bus to the clock. All other values are reserved. See Section 2.3.2.1 for an explanation of the bus. |
| 1   | Reserved | 0     | Always write 0 to this reserved bit.                                                                                                                                               |
| 0   | ENRX     |       | Enable receiver                                                                                                                                                                    |
|     |          | 0     | Disable this receiver.                                                                                                                                                             |
|     |          | 1     | Enable this receiver.                                                                                                                                                              |

## Table 9. SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL) Field Descriptions (continued)

#### Table 10. EQ Bits

| CFGRX[22–19] | Low Freq Gain | Zero Freq (at e <sub>28</sub> (min)) |  |  |
|--------------|---------------|--------------------------------------|--|--|
| 0000b        | Maximum       | -                                    |  |  |
| 0001b        | Adaptive      | Adaptive                             |  |  |
| 001xb        | R             | eserved                              |  |  |
| 01xxb        | R             | eserved                              |  |  |
| 1000b        | Adaptive      | 1084MHz                              |  |  |
| 1001b        |               | 805MHz                               |  |  |
| 1010b        |               | 573MHz                               |  |  |
| 1011b        |               | 402MHz                               |  |  |
| 1100b        |               | 304MHz                               |  |  |
| 1101b        |               | 216MHz                               |  |  |
| 1110b        |               | 156MHz                               |  |  |
| 1111b        |               | 135MHz                               |  |  |

#### 2.3.2.3 Enabling the Transmitter

To enable a transmitter for serialization, the ENTX bit of the associated SERDES\_CFGTX*n*\_CNTL registers (110h–10Ch) must be set high. When ENTX is low, all digital circuitry within the transmitter will be disabled, and clocks will be gated off, with the exception of the transmit clock (TXBCLK[*n*]) output, which will continue to operate normally. All current sources within the transmitter will be fully powered down, with the exception of the current mode logic (CML) driver, which will remain powered up if boundary scan is selected. Figure 11 shows the fields of SERDES\_CFGTX*n*\_CNTL and Table 11 describes them.

#### Figure 11. SERDES Transmit Channel Configuration Register n (SERDES\_CFGTXn\_CNTL)

| 31 |       |       |      |       |         |   |       |    |          |   | 17        | 16    |
|----|-------|-------|------|-------|---------|---|-------|----|----------|---|-----------|-------|
|    |       |       |      | Reser | ved     |   |       |    |          |   |           | ENFTP |
|    |       |       |      | R-0   | )       |   |       |    |          |   |           | R/W-1 |
| 15 | 1:    | 2 11  | 9    | 8     | 7       | 6 |       | 54 |          | 2 | 1         | 0     |
|    | DE    | SWING |      | СМ    | INVPAIR |   | RATE  |    | BUSWIDTH |   | (write 0) | ENTX  |
|    | R/W-0 | R/W-0 |      | R/W-0 | R/W-0   |   | R/W-0 |    | R/W-0    |   | R/W-0     | R/W-0 |
|    |       |       | 1/-1 | - 4   | -1      |   |       |    |          |   |           |       |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 11. SERDES Transmit Channel Configuration Register n (SERDES\_CFGTXn\_CNTL) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                               |
|-------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–17 | Reserved | 0     | These read-only bits return 0s when read.                                                                                                                                 |
| 16    | ENFTP    | 1     | Enables fixed phase relationship of transmit input clock with respect to transmit output clock. The only valid value for this field is 1b; all other values are reserved. |

| Table 11. SERDES Transmit Channel Configuration Register <i>n</i> (SERDES_CFGTX <i>n</i> _CNTL) Field |
|-------------------------------------------------------------------------------------------------------|
| Descriptions (continued)                                                                              |

| Bit   | Field    | Value       | Description                                                                                                                                                                                                                                                                                                          |
|-------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–12 | DE       | 0000b-1111b | De-emphasis. Selects one of 15 output de-emphasis settings from 4.76 to 71.42%. De-emphasis provides a means to compensate for high frequency attenuation in the attached media. It causes the output amplitude to be smaller for bits which are not preceded by a transition than for bits which are. See Table 12. |
| 11–9  | SWING    | 000b–111b   | Output swing. Selects one of 8 outputs amplitude settings between 125 and 1250mV_{dfpp}. See Table 13.                                                                                                                                                                                                               |
| 8     | СМ       |             | Common mode. Adjusts the common mode to suit the termination at the attached receiver. For output swing settings above 750mV, this reduced common mode can cause distortion of the waveform. Under these conditions, this bit should be set high to offset some of the common mode reduction.                        |
|       |          | 0           | Normal common mode. Common mode not adjusted.                                                                                                                                                                                                                                                                        |
|       |          | 1           | Raised common mode. Common mode raised by 5% of difference between RIOTXn and $\overline{\text{RIOTXn}}$                                                                                                                                                                                                             |
| 7     | INVPAIR  |             | Invert polarity. Inverts the polarity of RIOTXn and RIOTXn.                                                                                                                                                                                                                                                          |
|       |          | 0           | Normal polarity. RIOTXn is considered to be positive data and RIOTXn negative.                                                                                                                                                                                                                                       |
|       |          | 1           | Inverted polarity. RIOTXn is considered to be negative data and RIOTXn positive.                                                                                                                                                                                                                                     |
| 6–5   | RATE     |             | Operating rate. Selects full, half, or quarter rate operation.                                                                                                                                                                                                                                                       |
|       |          | 00b         | Full rate. Two data samples taken per PLL output clock cycle.                                                                                                                                                                                                                                                        |
|       |          | 01b         | Half rate. One data sample taken per PLL output clock cycle.                                                                                                                                                                                                                                                         |
|       |          | 10b         | Quarter rate. One data sample taken every two PLL output clock cycles.                                                                                                                                                                                                                                               |
|       |          | 11b         | Reserved                                                                                                                                                                                                                                                                                                             |
| 4–2   | BUSWIDTH | 000b        | Bus width. Always write 000b to this field, to indicate a 10-bit-wide parallel bus to the clock. All other values are reserved. See Section 2.3.2.1 for an explanation of the bus.                                                                                                                                   |
| 1     | Reserved | 0           | Always write 0 to this reserved bit.                                                                                                                                                                                                                                                                                 |
| 0     | ENTX     |             | Enable transmitter                                                                                                                                                                                                                                                                                                   |
|       |          | 0           | Disable this transmitter.                                                                                                                                                                                                                                                                                            |
|       |          | 1           | Enable this transmitter.                                                                                                                                                                                                                                                                                             |

#### Table 12. DE Bits of SERDES\_CFGTXn\_CNTL

|         | Amplitude Reduction |        |  |  |  |  |
|---------|---------------------|--------|--|--|--|--|
| DE Bits | %                   | dB     |  |  |  |  |
| 0000b   | 0                   | 0      |  |  |  |  |
| 0001b   | 4.76                | -0.42  |  |  |  |  |
| 0010b   | 9.52                | -0.87  |  |  |  |  |
| 0011b   | 14.28               | -1.34  |  |  |  |  |
| 0100b   | 19.04               | -1.83  |  |  |  |  |
| 0101b   | 23.8                | -2.36  |  |  |  |  |
| 0110b   | 28.56               | -2.92  |  |  |  |  |
| 0111b   | 33.32               | -3.52  |  |  |  |  |
| 1000b   | 38.08               | -4.16  |  |  |  |  |
| 1001b   | 42.85               | -4.86  |  |  |  |  |
| 1010b   | 47.61               | -5.61  |  |  |  |  |
| 1011b   | 52.38               | -6.44  |  |  |  |  |
| 1100b   | 57.14               | -7.35  |  |  |  |  |
| 1101b   | 61.9                | -8.38  |  |  |  |  |
| 1110b   | 66.66               | -9.54  |  |  |  |  |
| 1111b   | 71.42               | -10.87 |  |  |  |  |

| SWING Bits | Amplitude (mV <sub>dfpp</sub> ) |  |  |  |  |  |
|------------|---------------------------------|--|--|--|--|--|
| 000b       | 125                             |  |  |  |  |  |
| 001b       | 250                             |  |  |  |  |  |
| 010b       | 500                             |  |  |  |  |  |
| 011b       | 625                             |  |  |  |  |  |
| 100b       | 750                             |  |  |  |  |  |
| 101b       | 1000                            |  |  |  |  |  |
| 110b       | 1125                            |  |  |  |  |  |
| 111b       | 1250                            |  |  |  |  |  |

| Table | 13. | SWING | Bits | of | SERDES | CFGTX <i>n</i> | CNTL |
|-------|-----|-------|------|----|--------|----------------|------|
|       |     |       |      |    |        |                |      |

#### 2.3.2.4 SERDES Configuration Example

```
//full sample rate at 3.125 Gbps
//SERDES reference clock (RIOCLK) 125 MHz
             125MHz = ((3.125 Gbps)(.5))/MPY
//MPY = 12.5
SRIO_REGS->SERDES_CFG0_CNTL = 0x000000F;
SRIO REGS->SERDES CFG1 CNTL = 0x0000000;
SRIO_REGS->SERDES_CFG2_CNTL = 0x0000000;
SRIO_REGS->SERDES_CFG3_CNTL = 0x0000000;
// SRIO REGS->SERDES CFG1 CNTL not used
// SRIO_REGS->SERDES_CFG2_CNTL not used
// SRIO_REGS->SERDES_CFG3_CNTL not used
//four ports enabled
SRIO_REGS->SERDES_CFGRX0_CNTL = 0x00081101 ;
SRIO_REGS->SERDES_CFGRX1_CNTL = 0x00081101 ;
SRIO_REGS->SERDES_CFGRX2_CNTL = 0x00081101 ;
SRIO_REGS->SERDES_CFGRX3_CNTL = 0x00081101 ;
SRIO_REGS->SERDES_CFGTX0_CNTL = 0x00010801 ;
SRIO_REGS->SERDES_CFGTX1_CNTL = 0x00010801 ;
SRIO_REGS->SERDES_CFGTX2_CNTL = 0x00010801 ;
SRIO_REGS->SERDES_CFGTX3_CNTL = 0x00010801 ;
```

#### 2.3.3 Direct I/O Operation

The direct I/O (Load/Store) module serves as the source of all outgoing direct I/O packets. With direct I/O, the RapidIO packet contains the specific address where the data should be stored or read in the destination device. Direct I/O requires that a RapidIO source device keep a local table of addresses for memory within the destination device. Once these tables are established, the RapidIO source controller uses this data to compute the destination address and insert it into the packet header. The RapidIO destination peripheral extracts the destination address from the received packet header and transfers the payload to memory via the DMA.

When a CPU wants to send data from memory to an external processing element (PE) or read data from an external PE, it provides the RIO peripheral vital information about the transfer such as DSP memory address, target device ID, target destination address, packet priority, etc. Essentially, a means must exist to fill all the header fields of the RapidIO packet. The Load/Store module provides a mechanism to handle this information exchange via a set of MMRs acting as transfer descriptors. These registers, shown in Figure 12, are addressable by the CPU through the configuration bus. Upon completion of a write to LSU*n*\_REG5, a data transfer is initiated for either an NREAD, NWRITE, NWRITE\_R, SWRITE, ATOMIC, or MAINTENANCE RapidIO transaction. Some fields, such as the RapidIO *srcTID/targetTID* field, are assigned by hardware and do not have a corresponding command register field.

### Figure 12. Load/Store Registers for RapidIO (Address Offset: LSU1 400h–418h, LSU2 420h–438h, LSU3 440h–458h, LSU4 460h-478h)



The mapping of LSU register fields to RapidIO packet header fields is explained in Table 14 and Table 15. Table 14 has the fields of the control and command registers (LSU*n*\_REG0 through LSU*n*\_REG5), and Table 15 has the fields of the status register (LSU*n*\_REG6).

| LSU Register Field                   | RapidIO Packet Header Field                                                                                                                                                                                                                                                               |  |  |  |  |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| RapidIO Address MSB                  | 32-bit Extended Address Fields – Packet Types 2, 5, and 6                                                                                                                                                                                                                                 |  |  |  |  |
| RapidIO Address<br>LSB/Config_offset | <ol> <li>32-bit Address         – Packet Types 2, 5, and 6 (Will be used in conjunction with BYTE_COUNT to<br/>create 64-bit aligned RapidIO packet header address)</li> </ol>                                                                                                            |  |  |  |  |
|                                      | <ol> <li>24-bit Config_offset Field – Maintenance Packets Type 8 (Will be used in conjunction with<br/>BYTE_COUNT to create 64-bit aligned RapidIO packet header Config_offset). The 2 LSBs of<br/>this field must be zero since the smallest configuration access is 4 bytes.</li> </ol> |  |  |  |  |
| DSP Address                          | 32-bit DSP byte address. Not available in RapidIO Header.                                                                                                                                                                                                                                 |  |  |  |  |
| Byte_Count                           | Number of data bytes to Read/Write - up to 4K bytes. (Used in conjunction with RapidIO address to create WRSIZE/RDSIZE and WDPTR in RapidIO packet header.)                                                                                                                               |  |  |  |  |
|                                      | 000000000b - 4K bytes                                                                                                                                                                                                                                                                     |  |  |  |  |
|                                      | 0000000001b - 1 byte                                                                                                                                                                                                                                                                      |  |  |  |  |
|                                      | 0000000010b - 2 bytes                                                                                                                                                                                                                                                                     |  |  |  |  |
|                                      |                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                                      | 11111111111 – 4095 bytes                                                                                                                                                                                                                                                                  |  |  |  |  |
|                                      | (Maintenance requests are limited to 4 bytes)                                                                                                                                                                                                                                             |  |  |  |  |
| ID Size                              | RapidIO tt field specifying 8- or 16-bit DeviceIDs.                                                                                                                                                                                                                                       |  |  |  |  |
|                                      | 00b – 8-bit deviceIDs                                                                                                                                                                                                                                                                     |  |  |  |  |
|                                      | 01b – 16-bit deviceIDs                                                                                                                                                                                                                                                                    |  |  |  |  |
|                                      | 10b - reserved                                                                                                                                                                                                                                                                            |  |  |  |  |
|                                      | 11b - reserved                                                                                                                                                                                                                                                                            |  |  |  |  |
| Priority                             | RapidIO prio field specifying packet priority (0 = lowest, 3 = highest). Request packets should not be sent at a priority level of 3 to avoid system deadlock. It is the responsibility of the software to assign the appropriate outgoing priority.                                      |  |  |  |  |
| Xamsbs                               | RapidIO xamsb field specifying the extended address MSBs.                                                                                                                                                                                                                                 |  |  |  |  |

Table 14. LSU Control/Command Register Fields

| LSU Register Field | RapidIO Packet Header Field                                                                                                                                                  |  |  |  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| DestID             | RapidIO destinationID field specifying the target device.                                                                                                                    |  |  |  |  |  |
| Packet Type        | 4 MSBs: 4-bit ftype field for all packets                                                                                                                                    |  |  |  |  |  |
|                    | 4 LSBs: 4-bit trans field for packet types 2, 5, and 8                                                                                                                       |  |  |  |  |  |
| OutPortID          | Not available in RapidIO header.                                                                                                                                             |  |  |  |  |  |
|                    | Indicates the output port number for the packet to be transmitted from. Specified by the CPU along with NodeID.                                                              |  |  |  |  |  |
| Drbll Info         | RapidIO doorbell info field for type 10 packets. (see Table 23)                                                                                                              |  |  |  |  |  |
| Hop Count          | RapidIO hop_count field specified for Type 8 Maintenance packets.                                                                                                            |  |  |  |  |  |
| Interrupt Req      | Not available in RapidIO header.                                                                                                                                             |  |  |  |  |  |
|                    | CPU controlled request bit used for interrupt generation. Typically used in conjunction with non-posted commands to alert the CPU when the requested data/status is present. |  |  |  |  |  |
|                    | 0 - An interrupt is not requested upon completion of command                                                                                                                 |  |  |  |  |  |
|                    | 1- An interrupt is requested upon completion of command                                                                                                                      |  |  |  |  |  |

#### Table 14. LSU Control/Command Register Fields (continued)

### Table 15. LSU Status Register Fields

| LSU Register Field | Function                                                                                                                                             |  |  |  |  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| BSY                | Indicates status of the command registers.                                                                                                           |  |  |  |  |  |  |
|                    | 0 - Command registers are available (writable) for next set of transfer descriptors                                                                  |  |  |  |  |  |  |
|                    | 1 - Command registers are busy with current transfer                                                                                                 |  |  |  |  |  |  |
| Completion Code    | Indicates the status of the pending command.                                                                                                         |  |  |  |  |  |  |
|                    | 000b - Transaction complete, no errors (Posted/Non-posted)                                                                                           |  |  |  |  |  |  |
|                    | 001b - Transaction timeout occurred on Non-posted transaction                                                                                        |  |  |  |  |  |  |
|                    | 010b - Transaction complete, packet not sent due to flow control blockade (Xoff)                                                                     |  |  |  |  |  |  |
|                    | 011b – Transaction complete, non-posted response packet (type 8 and 13) contained ERROR status, or response payload length was in error              |  |  |  |  |  |  |
|                    | 100b – Transaction complete, packet not sent due to unsupported transaction type or invalid programming encoding for one or more LSU register fields |  |  |  |  |  |  |
|                    | 101b – DMA data transfer error                                                                                                                       |  |  |  |  |  |  |
|                    | 110b – Retry DOORBELL response received, or Atomic Test-and-swap was not allowed (semaphore in use)                                                  |  |  |  |  |  |  |
|                    | 111b – Transaction complete, packet not sent due to unavailable outbound credit at given priority (1)                                                |  |  |  |  |  |  |

<sup>(1)</sup> Status available only when busy (BSY) signal = 0.

Four LSU register sets exist. This allows four outstanding requests for all transaction types that require a response (i.e., non-posted). For multi-core devices, software manages the usage of the registers. A shared configuration bus accesses all register sets. A single core device can utilize all four LSU blocks.

Figure 13 shows the timing diagram for accessing the LSU registers. The busy (BSY) signal is deasserted. LSU*n*\_REG1 is written on configuration bus clock cycle T0, LSU*n*\_REG2 is written on cycle T1, LSU*n*\_REG3 is written on cycle T2, and LSU*n*\_REG4 is written on cycle T3. The command register LSU*n*\_REG5 is written on cycle T4. The extended address field in LSU*n*\_REG0 is assumed to be constant in this example. Upon completion of the write to the command register (next clock cycle T5), the BSY signal is asserted, at which point the preceding completion code is invalid and accesses to the LSU registers are not allowed. Once the transaction completes (either as a successful transmission, or unsuccessfully, such as flow control prevention or response timeout) and any required interrupt service routine is completed, the BSY signal is deasserted and the completion code becomes valid and the registers are accessible again.



# Figure 13. LSU Registers Timing

Figure 14 gives an example of the data flow and field mappings for a burst NWRITE\_R transaction.





For WRITE commands, the payload is combined with the header information from the control/command registers and buffered in the shared TX buffer resource pool. Finally, it is forwarded to the TX FIFO for transmission. READ commands have no payload. In this case, only the control/command register fields are buffered and used to create a RapidIO NREAD packet, which is forwarded to the TX FIFO. Corresponding response packet payloads from READ transactions are buffered in the shared RX buffer resource pool when forwarded from the receive ports. Both posted and non-posted operations rely on the OutPortID command register field to specify the appropriate output port/FIFO.

The data is burst internally to the Load/Store module at the DMA clock rate.

# 2.3.3.1 Detailed Data Path Description

The Load/Store module is for generating all outgoing RapidIO direct I/O packets. Any read or write transaction, other than the messaging protocol, uses this interface. In addition, outgoing DOORBELL packets are generated through this interface.

The data path for this module uses DMA bus as the DMA interface. The configuration bus is used by the CPU to access the control/command registers. The registers contain transfer descriptors that are needed to initiate READ and WRITE packet generation. After the transfer descriptors are written, flow control status is queried. The unit examines the DESTID and PRIORITY fields of LSU*n*\_REG4 to determine if that flow has been Xoffd. Additionally, the free buffer status of the TX FIFO is checked (based on the OutPortID register field). Only after the flow control access is granted, and a TX FIFO buffer has been allocated, can a DMA bus read command be issued for payload data to be moved into the shared TX buffer. Data is moved from the shared TX buffer to the appropriate output TX FIFO in simple sequential order based on completion of the DMA bus transaction. However, if fabric congestion occurs, priority can affect the order in which the data leaves the TX FIFOs.

Here a reordering mechanism exists, which transmits the highest priority packets first if RETRY acknowledges. Once in the FIFO, the data is guaranteed to be transmitted through the pins. Alternatively, if an intended flow has been shut down, the peripheral signals the CPU with an interrupt to notify that the packet was not sent and sets the completion code to 010b in the status register. The registers are held until the interrupt service routine is complete before the BSY signal is released (BSY=0 in LSUn\_REG6) and the CPU can then rewrite or overwrite the transfer descriptors with new data. Figure 15 illustrates the data path and buffering that is required to support the Load/Store module.





### Figure 15. Load/Store Module Data Flow Diagram

# 2.3.3.2 Direct I/O TX Operation

#### WRITE Transactions:

The TX buffers are implemented in a single SRAM and shared between multiple cores. A state machine arbitrates and assigns available buffers between the LSUs. When the DMA bus read request is transmitted, the appropriate TX buffer address is specified within it. The data payload is written to that buffer through the DMA bus response transaction. Depending on the architecture of the device, interleaving of multi-segmented DMA bus responses from the DMA is possible. Upon receipt of a DMA bus read response segment, the unit checks the completion status of the payload. Note that only one payload can be completed in any single DMA bus cycle. The Load/Store module can only forward the packet to the TX FIFO after the final payload byte from the DMA bus response has been written into the shared TX buffer. Once the packet is forwarded to the TX FIFO, the shared TX buffer can be released and made available for a new transaction.

The TX buffer space is dynamically shared among all outgoing sources, including the Load/Store module and the TX CPPI, as well as the response packets from RX CPPI and the memory access unit (MAU). Thus, the buffer space memory is partitioned to handle packets with and without payloads. A 4.5K-byte buffer space is configured to support 16 packets with payloads up to 256 bytes, in addition to 16 packets without payloads. The SRAM is configured as a 128-bit wide two port, which matches the UDI width of the TX FIFOs.

# Note: The "UDI" ("User Defined Interface") is a reference to the interface between (a) the SERDES and the FIFO queues and (b) the logical buffers, shared buffers, LSU and MAU modules, response timer, and controllers (together known as the "User Application"). UDI could also be known as the "logical/physical interface". No action is required to "define" this interface.



Data leaves the shared TX buffer sequentially in order of receipt, not based on the packet priority. However, if fabric congestion occurs, priority can affect the order in which the data leaves the TX FIFOs. A reordering mechanism exists here, which transmits the highest priority packets first if RETRY acknowledges.

For posted WRITE operations, which do not require a RapidIO response packet, a core may submit multiple outstanding requests. For instance, a single core may have many streaming write packets buffered at any given time, given outgoing resources. In this application, the control/command registers can be released (BSY = 0) to the CPU as soon as the header info is written into the shared TX buffer. If the request has been flow controlled, the peripheral will set the completion code status register and appropriate interrupt bit of the ICSR. The control/command registers can be released after the interrupt service routine completes.

For non-posted WRITE operations, which do require a RapidIO response packet, there can be only one outstanding request per core at any given time. The payload data and header information is written to the shared TX buffer as described above; however, the command registers cannot be released (BSY = 1) until the response packet is routed back to the module and the appropriate completion code is set in the status register. One special case exists for outgoing test-and-swap packets (Ftype 5, Transaction 1110b). This is the only WRITE class packet that expects a response with payload. This response payload is routed to the LSU, where it is examined to verify whether the semaphore was accepted, and then the appropriate completion code is set. The payload is not transferred out of the peripheral via the DMA bus.

So the general flow is as follows:

- LSU registers are written using the configuration bus
- Flow control is determined
- TX FIFO free buffer availability is determined
- DMA bus read request for data payload
- DMA bus response writes data to specified module buffer in the shared TX buffer space
- DMA bus read response is monitored for last byte of payload
- Header data in the LSU registers is written to the shared TX buffer space
- Payload and header are transferred to the TX FIFO
- The LSU registers are released if no RapidIO response is needed
- Transfer from the TX FIFO to external device based on priority

#### **READ Transactions:**

The flow for generating READ transactions is similar to non-posted WRITE with response transactions. There are two main differences: READ packets contain no data payload, and READ responses have a payload. So READ commands simply require a non-payload shared TX buffer. In addition, they require a shared RX buffer. This buffer is not pre-allocated before transmitting the READ request packet, since doing so could cause traffic congestion of other in-bound packets destined to other functional blocks.

Again, the control/command registers cannot be released (BSY = 1) until the response packet is routed back to the module and appropriate completion code is set in the status register.

So the general flow would be:

- LSU registers are written using the configuration bus
- Flow control is determined
- TX FIFO free buffer availability is determined
- Header data in the LSU registers is written to the shared TX buffer
- Payload and header are transferred to the TX FIFO
- The LSU registers are released if no RapidIO response is needed
- Transfer from the TX FIFO to external device based on priority

For all transactions, the shared TX buffers are released as soon as the packet is forwarded to the TX FIFOs. If an ERROR or RETRY response is received for a non-posted transaction, the CPU must either reinitiate the process by writing to the LSU register, or initiate a new transaction altogether.



#### SRIO Functional Description

#### Segmentation:

The LSU handles two types of segmentation of outbound requests. The first type is when the Byte\_Count of Read/Write requests exceeds 256 bytes (up to 4K bytes). The second type is when Read/Write request RapidIO address is non-64-bit aligned. In both cases, the outgoing request is broken up into multiple RapidIO request packets. For example, assume that the CPU wants to perform a 1K-byte store operation to an external RapidIO device. After setting up the LSU registers, the CPU performs one write to the LSU*n*\_REG5 register. The peripheral hardware then segments the store operation into four RapidIO write packets of 256 bytes each, and calculates the 64-bit-aligned RapidIO address, WRSIZE, and WDPTR as required for each packet. This example requires four outbound handles to be assigned and four DMA transmit requests. The LSU registers cannot be released until all posted request packets are passed to the TX FIFOs. Alternatively, for non-posted operations, such as CPU loads, all packet responses must be received before the LSU registers are released.

#### 2.3.3.3 Direct I/O RX Operation

Response packets are always type 13 RapidIO packets. All response packets with transaction types not equal to 0001b are routed to the LSU block sequentially in order of reception. These packets may have a payload, depending on the type of corresponding request packet that was originally sent. Due to the nature of RapidIO switch fabric systems, response packets can arrive in any order. The data payload, if any, and header data is moved from the RX FIFO to the shared RX buffer. The targetTID field of the packet is examined to determine which core and corresponding set of registers are waiting for the response. Remember, there can be only one outstanding request per core. Any payload data is moved from the shared RX buffer into memory through normal DMA bus operations.

Registers for all non-posted operations should only be held for a finite amount of time to avoid blocking resources when a request or response packet is somehow lost in the switch fabric. This time correlates to the 24-bit Port Response Time-out Control CSR value discussed in sections 5.10.1 and 6.1.2.4 of the RapidIO *Physical Layer 1x/4x LP-Serial Specification*. If the time expires, control/command register resources should be released, and an error is logged in the error-management RapidIO registers. The *RapidIO Interconnect Specification* states that the maximum time interval (all 1s) is between 3 and 6 seconds. A logical layer timeout occurs if the response packet is not received before a countdown timer (initialized to this CSR value) reaches zero.

Each outstanding packet response timer requires a 4-bit register. The register is loaded with the current timecode when the transaction is sent. The timecode comes from a 4 bit counter associated with the 24 bit down counter that continually counts down and is re-loaded with the value of SP\_RT\_CTL (Address offset 1124h) when it reaches 0. Each time the timecode changes, a 4-bit compare is done to the register. If the register becomes equal to the timecode again, without a response being seen, then the transaction has timed out. Essentially, instead of the 24-bit value representing the period of the response timer, the period is now defined as  $P = (2^24 \times 16)/F$ . This means the countdown timer frequency needs to be 44.7 – 89.5Mhz for a 6 – 3 second response timeout. Because the needed timer frequency is derived from the DMA bus clock (which is device dependent), the hardware supports a programmable configuration register field to properly scale the clock frequency. This configuration register field is described in the Peripheral Setting Control register (Address offset 0020h).

If a response packet indicates ERROR status, the Load/Store module notifies the CPU by generating an error interrupt for the pending non-posted transaction. If the response has completed successfully, and the Interrupt Req bit is set in the control register, the module generates a CPU servicing interrupt to notify the CPU that the response is available. The control/command registers can be released as soon as the response packet is received by the logical layer. The hardware is not responsible for attempting a retransmission of the non-posted transaction.

If a Doorbell response packet indicates Retry status, the Load/Store module notifies the CPU by generating an interrupt. The control/command registers can be released as soon as the response packet is received by the logical layer. The hardware is not responsible for attempting retransmission of the Doorbell transaction.



So the general flow is as follows:

- Previously, the control/command registers were written and the request packet was sent
- Response Packet Type13, Trans != 0001b arrives at module interface, and is handled sequentially (not based on priority)
- The argetTID is examined to determine routing of a response to the appropriate core
- The status field of the response packet is checked for ERROR, RETRY or DONE
- If the field is DONE, it submits DMA bus request and transmits the payload (if any) to DSP address. If the field is ERROR/RETRY, it sets an interrupt
- Command registers are released (BSY = 0)
- Optional Interrupt to CPU notifying packet reception

### 2.3.3.4 Reset and Power Down State

Upon reset, the Load/Store module clears the command register fields and wait for a write by the CPU.

The Load/Store module can be powered down if the direct I/O protocol is not being supported in the application. For example, if the messaging protocol is being used for data transfers, powering down the Load/Store module will save power. In this situation, the command registers should be powered down and inaccessible. Clocks should be gated to these blocks while in the power down state.

### 2.3.4 Message Passing

The Communications Port Programming Interface (CPPI) module is the incoming and outgoing message-passing protocol engine of the RapidIO peripheral. Messages contain application specific data that is pushed to the receiving device comparable to a streaming write. Messages do not contain read operations, but do have response packets.

With message passing, a destination address is not specified. Instead, a mailbox identifier is used within the RapidIO packet. The mailbox is controlled and mapped to memory by the local (destination) device. For RapidIO message passing, four mailbox locations are specified. Each mailbox can contain 4 separate transactions (or letters), effectively providing 16 messages. Single packet messages provide 64 mailboxes with 4 letters, effectively providing 256 messages. Mailboxes can be defined for different data types or priorities. The advantage of message passing is that the source device does not require any knowledge of the destination device's memory map. The DSP contains buffer description tables for each mailbox. These tables define a memory map and pointers for each mailbox. Messages are transferred to the appropriate memory locations via the DMA.

The data path for this module uses the DMA bus as the DMA interface. The ftype header field of the received RapidIO message packets are decoded by the logical layer of the peripheral. Only Type 11 and Type 13 (transaction type 1) packets are routed to this module. Data is routed from the priority-based RX FIFOs to the CPPI module's data buffer within the shared buffer pool. The mbox (mailbox) header fields are examined by the mailbox mapper block of the CPPI module. Based on the mailbox and message length, the data is assigned memory addresses within memory. Data is transferred via DMA bus commands to memory from the buffer space of the peripheral. The maximum buffer space should accommodate 256 bytes of data, as that is the maximum payload size of a RapidIO packet. Each message in memory will be represented by a buffer descriptor in the queue.

The following rules exist for all CPPI traffic:

- One buffer descriptor is provided per message (each buffer descriptor consists of 4 words or 16 bytes).
- Contiguous memory space is required for multi-segment read and write operations.
  - There are fixed buffer sizes (configured to handle the application's maximum message size).
- An ERROR response is sent if the RX message is too big for the allotted buffer space.
  - ERROR responses are sent for all subsequent segments of that message.
- An ERROR response is sent if the mailbox is not mapped, or if it is mapped to a non-existent queue.
- An ERROR response is sent if the mailbox is mapped but the queue is not initialized (the head descriptor pointer is not written), or if the queue is disabled (due to a teardown).
- An ERROR response is sent if the RX buffer descriptor queue has no empty buffers (there is an overflow).



- Out-of-order responses are allowed.
- A RETRY response is issued to the first received segment of a multi-segment message when the RX queue is busy servicing another request.
  - Subsequent RETRY responses may have to be sent for received pipeline segments or additional pipelined messages to the same queue.
- In-order message reception for dedicated flows is mode programmable.
- A queue is needed for each supported simultaneous multi-segment RX message.
- A minimum of 1.25K bytes of SRAM (64 buffer descriptors) is supported.
- The transmit source must be able to retry any given segment of a message.
- DestID is equal to port for TX operations, and the same DestID is not accessible from multiple ports.

#### 2.3.4.1 RX Operation

As message packets are received by the RapidIO ports, the data is written into memory while maintaining accurate state information that is needed for future processing. For instance, if a message spans multiple packets, information is saved that allows re-assembly of those packets by the CPU. The CPPI module provides a scheme for tracking single and multi-packet messages, linking messages in queues, and generating interrupts. Figure 16 illustrates the scheme.



#### Figure 16. CPPI RX Scheme for RapidIO

Messages addressed to any of the 64 mailbox locations can be received on any of the RapidIO ports simultaneously. Packets are handled sequentially in order of receipt. The function of the mailbox mapper block is to direct the inbound messages to the appropriate queue and finally to the correct core. The queue mapping is programmable and must be configured after device reset. RapidIO originally supported only 4 mailboxes with 4 letters/mailbox. Letters allow concurrent message traffic between sender and receiver. However, for messages that consist of only single packets, the unused 4-bit packet field normally indicating the message segment extends the available number of mailboxes. Figure 17 shows the packet header fields for message requests.



This enables the letter and mailbox fields to instead allow four concurrent single-segment messages to sixty-four possible mailboxes (256 total locations) for a source and destination pair. The mailbox mapper directs the inbound messages to the appropriate queue based on a pre-programmed routing table. It bases the decision on the SOURCEID, MSGLEN (the size indicates whether the message is segmented), MBOX, LETTER, and XMBOX fields of the RapidIO packet.

There are 32 programmable look-up table entries for mapping mailboxes to queues. Each entry consists of two registers, RXU\_MAP\_L*n* and RXU\_MAP\_H*n*, which are shown in Figure 18. A detailed summary of these register's field is in Section 5.50. In total, there are 64 registers, at address offsets 0800h–08FCh. Each entry stores the queue number associated with the message's intended mailbox/letter. If a mailbox/letter is not supported or does not have a mapping table entry, the message is discarded and an ERROR response sent. The mapping entries can explicitly call out a mailbox and letter combination, or alternatively, the mask fields can be used to grant multiple mailbox/letter mask fields indicates that the corresponding bit in the mailbox or letter field will not be used to match for this queue mapping entry. For example, a mailbox mask of all zeros would allow a mapping entry to be used for all incoming mailboxes.

The mapping table entry also provides a security feature to enable or disable access from specific external devices to local mailboxes. The sourceID field indicates which external device has access to the mapping entry and corresponding queue. A compare is performed between the sourceID of the incoming message packet and each relevant mailbox/letter table mapping entry SOURCEID field. If they do not match, an ERROR response is sent back to the sender, and the transaction is logged in the logical layer error management capture registers, which sets an interrupt. A PROMISCUOUS bit allows this security feature to be disabled. When the PROMISCUOUS bit is set, full access to the mapping entry from any sourceID is allowed. Note that when the PROMISCUOUS bit is cleared, it equals a mask value of FFFFh, and only a request with the matching sourceID is allowed access to the mailbox.

Each table entry also indicates if it used for single or multi-segment message mapping. Single segment message mapping entries utilize all six bits of the mailbox and corresponding mask fields. Multi-segment entries uses only the 2 LSBs. The number of simultaneous supported multi-segment messages is determined by the number of dedicated RX queues as discussed further below. It is recommended to dedicate a multi-segment mapping entry for each supported simultaneous letter. Essentially, letter masks should be avoided for multi-segment mapping to reduce excessive retries. Note that it is possible to configure the table entries such that incoming single segment and multi-segment messages are directed to the same queue. To avoid this condition, properly program the mapping table entries.



SRIO Functional Description

#### Figure 18. Mailbox to Queue Mapping Register Pair

| Mailbox to Queue Mappir | ng Register L <i>n</i> (RXU_MAP_L <i>n</i> ) |            |       |            |    |
|-------------------------|----------------------------------------------|------------|-------|------------|----|
| 31 30 29                |                                              | 24 23      | 22 21 |            | 16 |
| LETTER_MASK             | MAILBOX_MASK                                 | LETTE      | R     | MAILBOX    |    |
| R/W-11                  | R/W-111111                                   | R/W-00     | 0     | R/W-000000 |    |
| 15                      |                                              |            |       |            | 0  |
|                         |                                              | SOURCEID   |       |            |    |
|                         |                                              | P/M/ 0000h |       |            |    |

R/W-0000h

#### Mailbox to Queue Mapping Register H n (RXU\_MAP\_H n)

| 31       |        |          |          |             |                    |  |  |  |
|----------|--------|----------|----------|-------------|--------------------|--|--|--|
| Reserved |        |          |          |             |                    |  |  |  |
| R-0      |        |          |          |             |                    |  |  |  |
| 1        | 0 9 8  | 7 6      | 5        | 2 1         | 0                  |  |  |  |
| Reserved | TT     | Reserved | QUEUE_ID | PROMISCUOUS | SEGMENT<br>MAPPING |  |  |  |
| R-0      | R/W-01 | R-00     | R/W-0000 | R/W-0       | R/W-0              |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

The packet manager maintains the RX DMA state of free and used data buffers within the memory space. It directs the data to specific addresses within the memory and maintains and updates the buffer descriptor queues. There is a single buffer descriptor per RapidIO message. For example, single segment messages have one buffer descriptor, as do multi-segment messages with up to 4K-byte payloads.

There can be multiple RX buffer descriptor queues per core. It is suggested that one queue be dedicated to single segment messages and additional queues be dedicated to multi-segment messages. Each multi-segment message queue can support only one incoming message at a time. Depending on the application, it may be necessary to support multiple simultaneous segmentation and reassembly (SAR) operations per core. In this case, a buffer descriptor queue is allocated for each desired simultaneous message. The peripheral supports a total of 16 assignable RX gueues and their associated RX DMA state registers. Each of the queues can be assigned to single or multi-segment messages.

Table 16 and Table 17 describe the RX DMA State Registers.

#### Table 16. RX DMA State Head Descriptor Pointer (HDP) (Address Offset 600h–63Ch)

| Bit  | Name                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | RX Queue Head<br>Descriptor Pointer | RX Queue Head Descriptor Pointer: This field is the memory address for the first buffer descriptor<br>in the channel receive queue. This field is written by the DSP core to initiate queue receive<br>operations and is zeroed by the port when all free buffers have been used. An error condition<br>results if the DSP core writes this field when the current field value is nonzero. The address must<br>be 32-bit word aligned. |

#### Table 17. RX DMA State Completion Pointer (CP) (Address Offset 680h–6BCh)

| Bit  | Name | Description                                                                                                                                                                                                                                                                                                                                        |
|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 |      | RX Queue Completion Pointer: This field is the memory address for the receive queue completion pointer. This register is written by the DSP core with the buffer descriptor address for the last buffer processed by the DSP core during interrupt processing. The port uses the value written to determine if the interrupt should be deasserted. |

If a multi-segment buffer descriptor queue is not currently free, and an RX port receives another multi-segment message that is destined for that queue, the RX CPPI sends a RETRY RESPONSE packet (type 13) to the sender, indicating that an internal buffering problem exists. If a multi-segment buffer descriptor queue is busy and there is another incoming multi-segment message with the same SOURCEID, MAILBOX, and LETTER, an ERROR response is sent. This usually indicates that a TX programming error has occurred, where duplicate segments or segments outside the MSGLEN were sent. Upon successful reception of any message segment, the RX CPPI is responsible for sending a DONE response to the sender.

If a RX message's length is greater than that of the targeted buffer descriptor, an ERROR response is sent back to the source device. In addition, the DSP is notified with the use of the CC field of the RX CPPI buffer descriptor, described as follows. This situation can result from a DSP software error (misallocating a buffer for the queue), or as a result of sender error (sending to a wrong mailbox).

An RX transaction timeout is used by all multi-segment queues, in order to not hang receive mailbox resources in the event that a message segment is lost in the fabric. This response-to-request timer controls the time-out period for sending a response packet and receiving the next request packet of a given multi-segment message. It has the same value and is analogous to the request-to-response timer discussed in the TX CPPI and LSU sections, which is defined by the 24-bit value in the port response timerout CSR (See Section 2.3.3.3). The *RapidIO Interconnect Specification* states that the maximum time interval (all 1s) is between 3 and 6 seconds. Each multi-segment receive timer requires a 4-bit register. The register is loaded with the current timecode when the response is sent. Each time the timecode changes, a 4-bit compare is done to the register. If the register becomes equal to the timecode again, without the next message segment being seen, then the transaction has timed out. If this happens, the RX buffer resources can be released.

The buffer descriptor points to the corresponding data buffer in memory and also points to the next buffer descriptor in the queue. As segments of a received message arrive, the msgseg field of each segment is monitored to detect the completion of the received message. Once a full message is received, the OWNERSHIP bit is cleared in the packet's buffer descriptor to give control to the host. At this point, a host interrupt is issued. This interface works with programmable interrupt rate control. There is an ICSR bit for each supported queue. On interrupt, the CPU processes the RX buffer queue, detecting received packets by the status of the OWNERSHIP bit in each buffer descriptor. The host processes the RX queue until it reaches a buffer descriptor with a set OWNERSHIP bit, or set EOQ bit. Once processing is complete, the host updates the RX DMA State Completion Pointer, allowing the peripheral to reuse the buffer.

Figure 19 shows the RX buffer descriptor fields and Table 18 describes them. A RX buffer descriptor is a contiguous block of four 32-bit data words aligned on a 32-bit boundary. Accesses to these registers are restricted to 32-bit boundaries.

| Word   |             | Bit Fields                                                                           |                                           |             |                                 |  |   |       |  |    |        |   |     |    |   |      |      |    |      |     |     |       |   |  |
|--------|-------------|--------------------------------------------------------------------------------------|-------------------------------------------|-------------|---------------------------------|--|---|-------|--|----|--------|---|-----|----|---|------|------|----|------|-----|-----|-------|---|--|
| Offset | 31          | 1 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |                                           |             |                                 |  |   |       |  |    |        |   |     |    |   |      |      |    |      |     |     |       |   |  |
| 0      |             | next_descriptor_pointer                                                              |                                           |             |                                 |  |   |       |  |    |        |   |     |    |   |      |      |    |      |     |     |       |   |  |
| 1      |             | buffer_pointer                                                                       |                                           |             |                                 |  |   |       |  |    |        |   |     |    |   |      |      |    |      |     |     |       |   |  |
| 2      |             |                                                                                      |                                           |             |                                 |  | s | rc_id |  |    |        |   | pri | tt |   | rese | rved |    |      |     | ma  | ilbo> | < |  |
| 3      | s<br>o<br>p | e<br>o<br>p                                                                          | o<br>w<br>n<br>e<br>r<br>s<br>h<br>i<br>p | e<br>o<br>q | t<br>a<br>r<br>d<br>o<br>w<br>n |  |   |       |  | re | eserve | d |     |    | С | с    |      | me | essa | ge_ | len | gth   |   |  |

| Figure 19. RX Buffer Descripte | or Fields |
|--------------------------------|-----------|
|--------------------------------|-----------|

#### Table 18. RX Buffer Descriptor Field Descriptions

| Field                   | Description                                                                                                                                                                                                                                                                                                                                 |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| next_descriptor_pointer | Next Descriptor Pointer: The 32-bit word aligned memory address of the next buffer descriptor in the RX queue. This references the next buffer descriptor from the current buffer descriptor. If the value of this pointer is zero, then the current buffer is the last buffer in the queue. The DSP core sets the next_descriptor_pointer. |
| buffer_pointer          | Buffer Pointer: The byte aligned memory address of the buffer associated with the buffer descriptor. The DSP core sets the buffer_pointer.                                                                                                                                                                                                  |
| sop = 1                 | <ul><li>Start of Message: Indicates that the descriptor buffer is the first buffer in the message.</li><li>This bit will always be set, as this device only supports one buffer per message.</li></ul>                                                                                                                                      |
| eop = 1                 | <ul><li>End of Message: Indicates that the descriptor buffer is the last buffer in the message.</li><li>This bit will always be set, as this device only supports one buffer per message.</li></ul>                                                                                                                                         |



| Field             | Description                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| ownership         | Ownership: Indicates ownership of the message and is valid only on sop. This bit is see<br>by the DSP core and cleared by the port when the message has been transmitted. The<br>DSP core uses this bit to reclaim buffers.<br>0: The message is owned by the DSP core                                                              |  |  |  |  |  |  |  |  |
|                   | 0: The message is owned by the DSP core                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|                   | 1: The message is owned by the port                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| eoq               | End Of Queue: Set by the port to indicate that the RX queue empty condition exists.<br>This bit is valid only on eop. The port determines the end of queue condition by a zero<br>next_descriptor_pointer.                                                                                                                          |  |  |  |  |  |  |  |  |
|                   | 0: The RX queue has more buffers available for reception.                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
|                   | 1: The Descriptor buffer is the last buffer in the last message in the queue.                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| teardown_complete | Teardown Complete: Set by the port to indicate that the host commanded teardown process is complete, and the channel buffers may be reclaimed by the host.                                                                                                                                                                          |  |  |  |  |  |  |  |  |
|                   | 0: The port has not completed the teardown process.                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|                   | 1: The port has completed the commanded teardown process.                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
| message_length    | Message Length: Initially written by the DSP core to specify the maximum number of double-words the buffer can receive. Updated by the peripheral (after receiving a message) to indicate the actual number of double-words in the entire message. Message payloads are limited to a maximum size of 512 double-words (4096 bytes). |  |  |  |  |  |  |  |  |
|                   | 00000000b: 512 double words                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                   | 00000001b: 1 double word                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
|                   | 00000010b: 2 double words                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
|                   |                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                   | 111111111b: 511 double words                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| src_id            | Source Node ID: Unique node identifier of the source of the message. Written by the DSP core.                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| tt                | RapidIO tt field specifying 8- or 16-bit DeviceIDs. Written by the DSP core.                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
|                   | 00b: 8-bit deviceIDs                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|                   | 01b: 16-bit deviceIDs                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|                   | 10: reserved                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
|                   | 11: reserved                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| pri               | Message Priority: Specifies the SRIO priority at which the message was sent. Written by the DSP core.                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| CC                | Completion Code: Written by the port.                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|                   | 000: Good completion. Message received.                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|                   | 001: Error, RX message length greater than supported buffer descriptor message_length                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|                   | 010: Error, TimeOut on receiving one of the segments                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|                   | 011: DMA transfer error on one or more segments                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                   | 100: Queue teardown completed, data invalid                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|                   | 101: 111 Reserved                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| mailbox           | Destination Mailbox: Specifies the mailbox to which the message was sent. Written by the DSP core.                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|                   | 000000b: Mailbox 0                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|                   | 000001b: Mailbox 1                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|                   |                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                   | 000100b: Mailbox 4                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|                   |                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                   | 111111b: Mailbox 63                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|                   | For multi-segment messages, only the two LSBs of this mailbox are valid. Hardware ignores the four MSBs if the incoming message has multiple segments.                                                                                                                                                                              |  |  |  |  |  |  |  |  |

# Table 18. RX Buffer Descriptor Field Descriptions (continued)



Although the switch fabric delivers the segments of multi-packet messages in the order they were sent, buffer resources at the receiving endpoint may only become available after the initial segment(s) of a message have had to be retried. The peripheral can accept out-of-order segments and track completion of the overall message. Scenario A in Figure 20 shows this concept.

For applications that are set up for specific message flows between a single source and destination, it may require in-order delivery of messages. This is described in scenario B of Figure 20. This scenario is similar to scenario A, although one message may be retried due to a lack of receiver resources, subsequent pipelined messages may arrive just as resources are freed up. This is a problem for systems requiring in-order message delivery. In this case, the peripheral needs to record the Src\_id/mailbox/letter of the first retried message and retry all subsequent new requests until resources are available and a segment for that Src\_id/mailbox/letter is received. As long as all messages are from the same source and that source sends (and retries) packets in order, then all messages will be received in order. Note that this solution is less effective when multiple sources share an RX queue. The RX CPPI Control register (Address offset 0744h) sets this mode of operation on all receive queues. Once this mode is set and a retry is issued, the queue will continue to wait for an incoming message that matches the Src\_id/mailbox/letter combination. If no such packet arrives, the RX queue is unusable in a locked state. To reenable the queue, the in-order bit in the RX CPPI Control register must be disabled by software for that queue, after which it may be enabled again if desired. The in-order mode of operation is only valid on multi-segment queues because single-segment messages will never generate RETRY responses.





#### SRIO Functional Description

In addition, multiple messages can be interleaved at the receive port due to ordering within a connected switch's output queue. This can occur when using a single or multiple priorities. The RX CPPI block can handle simultaneous interleaved multi-segment messages. This implies that state information (write pointers and sourceID) is maintained on each simultaneous message to properly store the segments in memory. The number of simultaneous transactions supported directly impacts the number of states to be stored, and the size of the buffer descriptor memory outside the peripheral. With this in mind, the peripheral's supported buffer descriptor SRAM is parameterizable. A minimum size of 1.25K bytes is recommended, which will allow up to 64 buffer descriptors to be stored at any given time for one core. These buffer descriptors can be configured to support any combination of single and multi-segment messages. For example, if the application only handles single-segment messages, all 64 buffers can be allotted to that queue. Note that a given RX queue can contain packets of all priorities which have been directed from any of the receive ports.

A CPU may wish to stop receiving messages and reclaim buffers belonging to a specific queue. This is called queue teardown. The CPU initiates a RX queue teardown by writing to the RX Queue Teardown command register (Address Offset 0740h).

Teardown of an RX queue causes the following actions:

- If teardown is issued by software during the time when the RX state machine is idle, then the state machine will immediately start the teardown procedure:
  - If the queue to be torn down is in-message (waiting for one or more segments), then the queue will be torn down and reported with the current buffer descriptor (teardown bit set, ownership bit cleared, CC = 100b). All other fields of the buffer descriptor are invalid. The peripheral completes the teardown procedure by clearing the HDP register, setting the CP register to FFFFFFCh, and issuing an interrupt for the given queue. The teardown command register bit is automatically cleared by the peripheral.
  - If the queue is not in-message, and active (next descriptor available), then the next descriptor will be fetched and updated to report teardown (teardown bit set, ownership bit cleared, CC = 100b). All other fields of the buffer descriptor are invalid. The peripheral completes the teardown procedure by clearing the HDP register, setting the CP register to FFFFFFCh, and issuing an interrupt for the given queue. The teardown command register bit is automatically cleared by the peripheral.
  - If the queue is not in-message, but inactive (next descriptor unavailable), then no additional buffer descriptor will be written. The HDP register and the CP register remain unchanged. An interrupt is not issued. The teardown command register bit is automatically cleared by the peripheral.
- If teardown is issued by software during the time when the RXU state machine is busy, the teardown
  procedure will be postponed until the state machine is idle.

After the teardown process is complete and the interrupt is serviced by the CPU, the software must re-initialize the RX queue to restart normal operation.

The buffer descriptor queues are maintained in local SRAM just outside of the peripheral, as shown in Figure 21. This allows the quickest access time, while maintaining a level of configurability for device implementation. The SRAM is accessible by the CPU through the configuration bus. Alternatively, the buffer descriptors could use L2 memory as well.

# Figure 21. CPPI Boundary Diagram



# 2.3.4.2 TX Operation

Outgoing messages are handled similarly, with buffer descriptor queues that are assigned by the CPUs. The queues are configured and initialized upon reset. When a CPU wants to send a message to an external RapidIO device, it writes the buffer descriptor information via the configuration bus into the SRAM. Again, there is a single buffer descriptor per RapidIO message. Upon completion of writing the buffer descriptor, the OWNERSHIP bit is set to give control to the peripheral. The CPU then writes the TX DMA State HDP register to initiate the queue transmit. For TX operation, PortID is specified to direct the outgoing packet to the appropriate port. Table 19 and Table 20 describe the TX DMA state registers. Figure 22 shows the TX buffer descriptor fields and Table 21 describes them. A TX buffer descriptor is a contiguous block of four 32-bit data words aligned on a 32-bit boundary.

| Table 19. | TX DMA | <b>State Head</b> | Descriptor | Pointer (HDP) | (Address | Offset 500h–53Ch) |
|-----------|--------|-------------------|------------|---------------|----------|-------------------|
|           |        |                   |            |               |          |                   |

| Bit  | Name                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | TX Queue Head<br>Descriptor Pointer | TX Queue Head Descriptor Pointer: This field is the DSP core memory address for the first buffer descriptor in the transmit queue. This field is written by the DSP core to initiate queue transmit operations and is zeroed by the port when all packets in the queue have been transmitted. An error condition results if the DSP core writes this field when the current field value is nonzero. The address must be 32-bit word aligned. |



# Table 20. TX DMA State Completion Pointer (CP) (Address Offset 58h–5BCh)

| Bit  | Name                           | Description                                                                                                                                                                                                                                                                                                                                                  |
|------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | TX Queue<br>Completion Pointer | TX Queue Completion Pointer: This field is the DSP core memory address for the transmit queue completion pointer. This register is written by the DSP core with the buffer descriptor address for the last buffer processed by the DSP core during interrupt processing. The port uses the value written to determine if the interrupt should be deasserted. |

| Word   |             |             |                                           |        |                            |       |    |        |      |    |       | I    | Bit F | ield | s   |     |      |     |      |   |    |      |   |      |     |      |       |   |   |
|--------|-------------|-------------|-------------------------------------------|--------|----------------------------|-------|----|--------|------|----|-------|------|-------|------|-----|-----|------|-----|------|---|----|------|---|------|-----|------|-------|---|---|
| Offset | 31          | 30          | 29                                        | 28     | 27                         | 26 25 | 24 | 23 22  | 2 21 | 20 | 19 18 | 3 17 | 16    | 15   | 14  | 13  | 3 12 | 11  | 10   | 9 | 8  | 7    | 6 | 5    | 4   | 3    | 2     | 1 | 0 |
| 0      |             |             |                                           |        |                            |       |    |        |      |    |       |      | escri |      |     |     |      |     |      |   |    |      |   |      |     |      |       |   |   |
| 1      |             |             |                                           |        |                            |       |    |        |      |    |       | bu   | ffer_ | poir | ter |     |      |     |      |   |    |      |   |      |     |      |       |   |   |
| 2      |             |             |                                           |        |                            |       | de | est_id |      |    |       |      |       | р    | ri  |     | tt   | por | t_id |   | SS | size |   |      |     | m    | ailbo | х |   |
| 3      | s<br>o<br>p | e<br>o<br>p | o<br>w<br>n<br>e<br>r<br>s<br>h<br>i<br>p | e<br>q | t<br>a<br>r<br>d<br>w<br>n |       |    | reser  | ved  |    |       |      | re    | try_ | cou | ınt |      |     | сс   |   |    |      | m | essa | age | _ler | ngth  |   |   |

# Figure 22. TX Buffer Descriptor Fields

# Table 21. TX Buffer Descriptor Field Definitions

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                        |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| next_descriptor_pointer | Next Descriptor Pointer: The 32-bit word aligned memory address of the next buffer descriptor in the TX queue. This is the mechanism used to reference the next buffer descriptor from the current buffer descriptor. If the value of this pointer is zero then the current buffer is the last buffer in the queue. The DSP core sets the next_descriptor_pointer. |
| buffer_pointer          | Buffer Pointer: The byte aligned memory address of the buffer associated with the buffer descriptor. The DSP core sets the buffer_pointer.                                                                                                                                                                                                                         |
| sop = 1                 | <ul><li>Start of Message: Indicates that the descriptor buffer is the first buffer in the message.</li><li>This bit will always be set as this device only supports one buffer per message.</li></ul>                                                                                                                                                              |
| eop = 1                 | <ul><li>End of Message: Indicates that the descriptor buffer is the last buffer in the message.</li><li>This bit will always be set as this device only supports one buffer per message.</li></ul>                                                                                                                                                                 |
| ownership               | Ownership: Indicates ownership of the message and is valid only on sop. This bit is set<br>by the DSP core and cleared by the port when the message has been transmitted. The<br>DSP core uses this bit to reclaim buffers.                                                                                                                                        |
|                         | 0: The message is owned by the DSP core                                                                                                                                                                                                                                                                                                                            |
|                         | 1: The message is owned by the port                                                                                                                                                                                                                                                                                                                                |
| eoq                     | End Of Queue: Set by the port to indicate that all messages in the queue have been transmitted and the TX queue is empty. End of queue is determined by the port when the next_descriptor_pointer is zero on an eop buffer. This bit is valid only on eop.                                                                                                         |
|                         | 0: The TX queue has more messages to transfer.                                                                                                                                                                                                                                                                                                                     |
|                         | 1: The Descriptor buffer is the last buffer in the last message in the queue.                                                                                                                                                                                                                                                                                      |
| teardown_complete       | Teardown Complete: Set by the port to indicate that the DSP core commanded teardown process is complete, and the channel buffers may be reclaimed by the DSP core.                                                                                                                                                                                                 |
|                         | 0: The port has not completed the teardown process.                                                                                                                                                                                                                                                                                                                |
|                         | 1: The port has completed the commanded teardown process.                                                                                                                                                                                                                                                                                                          |

| Field          | Description                                                                                                                                                                                                                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| retry_count    | Message Retry Count: Set by the DSP core to indicate the total number of retries allowed for this message, including all segments. Decremented by the port each time a message is retried.                                                                                                                                      |
|                | 000000b: Infinite Retries                                                                                                                                                                                                                                                                                                       |
|                | 000001b: Retry Message 1 time                                                                                                                                                                                                                                                                                                   |
|                | 000002b: Retry Message 2 times                                                                                                                                                                                                                                                                                                  |
|                |                                                                                                                                                                                                                                                                                                                                 |
|                | 111111b: Retry Message 63 times                                                                                                                                                                                                                                                                                                 |
| сс             | Completion Code: Set by the port.                                                                                                                                                                                                                                                                                               |
|                | 000: Good Completion. Message received a done response.                                                                                                                                                                                                                                                                         |
|                | 001: Transaction error. Message received an error response. *                                                                                                                                                                                                                                                                   |
|                | 010: Excessive Retries. Message received more than retry_count retry responses.                                                                                                                                                                                                                                                 |
|                | 011: Transaction timeout. Transaction timer elapsed without any message response being received.                                                                                                                                                                                                                                |
|                | 100: DMA data transfer error                                                                                                                                                                                                                                                                                                    |
|                | 101: Descriptor Programming error                                                                                                                                                                                                                                                                                               |
|                | 110: TX Queue Teardown Complete                                                                                                                                                                                                                                                                                                 |
|                | 111: Outbound Credit not available.                                                                                                                                                                                                                                                                                             |
|                | * An ERROR transfer completion code indicates an error in one or more segments of a transmitted multi-segment message.                                                                                                                                                                                                          |
| message_length | Message Length: Message Length – Written by the DSP core to specify the number of double-words to transmit. Message payloads are limited to a maximum size of 512 double-words (4096 bytes).                                                                                                                                    |
|                | 00000000b: 512 double words                                                                                                                                                                                                                                                                                                     |
|                | 00000001b: 1 double word                                                                                                                                                                                                                                                                                                        |
|                | 00000010b: 2 double words                                                                                                                                                                                                                                                                                                       |
|                |                                                                                                                                                                                                                                                                                                                                 |
|                | 111111111b: 511 double words                                                                                                                                                                                                                                                                                                    |
| dest_id        | Destination Node Id: Unique Node identifier for the Destination of the message. Written by the DSP core.                                                                                                                                                                                                                        |
| pri            | Message Priority: Specifies the SRIO priority at which the message will be sent.<br>Messages should not be sent at a priority level of 3 because the message response is<br>required to promote the priority to avoid system deadlock. It is the responsibility of the<br>software to assign the appropriate outgoing priority. |
| tt             | RapidIO tt field specifying 8- or 16-bit DeviceIDs. Written by the host.                                                                                                                                                                                                                                                        |
|                | 00: 8-bit deviceIDs                                                                                                                                                                                                                                                                                                             |
|                | 01: 16-bit deviceIDs                                                                                                                                                                                                                                                                                                            |
|                | 10: reserved                                                                                                                                                                                                                                                                                                                    |
|                | 11: reserved                                                                                                                                                                                                                                                                                                                    |
| port_id        | Port number for routing outgoing packet. Written by the DSP core.                                                                                                                                                                                                                                                               |

| Table 21. TX Buffer | Descriptor F | Field Definitions | (continued) |
|---------------------|--------------|-------------------|-------------|
|---------------------|--------------|-------------------|-------------|

| Field   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| ssize   | RIO standard message payload size. Indicates how the hardware should segment the outgoing message by specifying the maximum number of double-words per packet. If the message is a multi-segment message, this field remains the same for all outgoing segments. All segments of the message, except for the last segment, have payloads equal to this size. The last message segment may be equal or less than this size. Maximum message size for a 16 segment message is shown below. Message_length/16 must be less than or equal to Ssize, if not, the message is not sent and CC 101b is set. Written by the DSP core. |  |  |  |  |  |
|         | 0000b - 1000b: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|         | 1001b: 1 Double-word payload (Supports up to a 128-byte message)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|         | 1010b: 2 Double-word payload (Supports up to a 256-byte message)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|         | 1011b: 4 Double-word payload (Supports up to a 512-byte message)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|         | 1100b: 8 Double-word payload (Supports up to a 1024-byte message)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|         | 1101b: 16 Double-word payload (Supports up to a 2048-byte message)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|         | 1110b: 32 Double-word payload (Supports up to a 4096-byte message)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|         | 1111b: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| mailbox | Destination Mailbox: Specifies the mailbox to which the message will be sent. Written by the DSP core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|         | 000000b: Mailbox 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|         | 000001b: Mailbox 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|         | 000100b: Mailbox 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|         | 111111b: Mailbox 63                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|         | For multi-segment messages, only the 2 LSBs of this mailbox field are valid. Hardware will ignore the 4 MSBs of this field if the outgoing message is multi-segment.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |

| Table 21. | <b>TX Buffer</b> | Descriptor | Field | Definitions | (continued) |
|-----------|------------------|------------|-------|-------------|-------------|
|-----------|------------------|------------|-------|-------------|-------------|

Once the port controls the buffer descriptor, the DEST\_ID field can be queried to determine flow control. If the transaction has been flow controlled, the DMA bus READ request is postponed so that the TX buffer space is not wasted. Because buffer descriptors cannot be reordered in the link list, if the transaction at the head of the buffer descriptor queue is flow controlled, head-of-line (HOL) blocking will occur on that queue. When this occurs, all transactions located in that queue are stalled. To counter the effects and reduce back-up of more TX packets, multiple queues are available. The peripheral supports a total of 16 assignable TX queues and their associated TX DMA state registers. The transmission order between queues is based on a programmable weighted round-robin scheme at the message level. The programmable control registers are shown in Figure 23. This scheme allows configurability of the queue transmission order, as well as the weight of each queue within the round robin.

The TX state machine begins by processing the current TX\_Queue\_Map(n). It will attempt to process the queue and number of buffer descriptors from that queue programmed in this mapping entry. Then it will move to TX\_Queue\_Map(n+1), followed by TX\_Queue\_Map(n+2) and so forth. It is important to note that this mapping order is fixed in a circular pattern. Each mapper can point to any queue and multiple mappers can point to a single queue. If a mapper points to an inactive queue, the peripheral recognizes this and moves to the next mapper. In order for an active queue to transmit packets, at least one mapper must be pointing to that queue. The default settings dictate an equally weighted round-robin that starts on queue0 and increments by one until reaching queue15.

The round-robin scheme does not provide precise control over the order of data sent out of the device. The ordering of the messages provided by the entries in the Weighted Round Robin Programming Registers is not an absolute guarantee of the actual transmission order or receive order of the messages. For example, take a case where there are two active queues and the TX\_Queue\_Map registers are setup to continuously send 2 messages from Queue 0, followed by 1 message from Queue 1. If the first message from Queue 0 attempts to reuse a mailbox/letter combination already in use (Content Addressable Memory (CAM) violation), or fails to gain outbound credit due to buffer congestion at a given priority, then the state machine will re-evaluate the TX\_Queue\_Map to decide on the next step. Since the TX\_Queue\_Map has been programmed to send two messages from Queue 0 before moving to Queue 1, it will re-attempt to send the same message from Queue 0 before moving on. Whether it is successful or not, the next attempt will come from Queue 1. Within a given queue, the hardware will always try to send the head buffer descriptor and can not move to the next buffer descriptor in the queue until a completion code is written. The weighted round robin control advocates, that statistically over many transmissions, the messages will be transmitted in accordance with the percentages programmed into the registers.

Network traffic can also affect the packet delivery order. The physical layer of the RapidIO peripheral can re-order packets of different priorities when fabric congestion occurs.

If message ordering is needed, the following must be obeyed:

- Multi Segmented Messages
  - If there are only two devices A sending to B where ordering has to be guaranteed:
    - - Use one TX queue
    - - Use the same priority
    - - Map all messages to the same RX queue
  - If there are multiple devices A and B both sending to C, and ordering has to be guaranteed for both:
    - - Use one TX queue in each sending device
    - - Use the same priority within each TX queue
    - - Map all A messages to the same RX queue and all B messages to another queue by disabling the promiscuous mode and programming allowable sourceIDs.
- Single Segmented Messages
  - There will never be a retry so even if there are multiple senders:
    - - Use one TX queue in each sending device
    - - Use the same priority within each TX queue
    - - Map all messages to the same RX queue



| SRIO | Functional | Descri | ption |
|------|------------|--------|-------|
|------|------------|--------|-------|

| тх с | Figure 23. Wei         | ighted Round Robin Progr<br>ffset 7E0h | amm | ing Registers (Addre | ss Offset /EUh-/ECh) |  |  |  |  |
|------|------------------------|----------------------------------------|-----|----------------------|----------------------|--|--|--|--|
| _    | -                      | eue_Map3>                              | <   | TX Q                 | ueue Map2            |  |  |  |  |
| 31   |                        | •                                      | 23  |                      | 0 19                 |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-3h                                 | 1   | R/W-0                | R/W-2h               |  |  |  |  |
| <    | TX Que                 | eue_Map1>                              | <   | TX Q                 | ueue Map0            |  |  |  |  |
| 15   |                        |                                        | 7   |                      | 4 3                  |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-1h                                 |     | R/W-0h               | R/W-0h               |  |  |  |  |
| тх_с | UEUE_CNTL1 - Address O | ffset 7E4h                             |     |                      |                      |  |  |  |  |
| <    | TX_Que                 | eue_Map7>                              | <   | TX_Q                 | ueue_Map6            |  |  |  |  |
| 31   | 28                     | 27 24                                  | 23  | 20                   | 0 19                 |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0                  | R/W-7h                                 |     | R/W-0h               | R/W-6h               |  |  |  |  |
| <    | TX_Que                 | eue_Map5>                              | <   | TX_Q                 | ueue_Map4            |  |  |  |  |
| 15   | 12                     | 11 8                                   | 7   |                      | 4 3                  |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-5h                                 |     | R/W-0h               | R/W-4h               |  |  |  |  |
| тх_с | UEUE_CNTL2 - Address O | ffset 7E8h                             |     |                      |                      |  |  |  |  |
| <    | TX_Que                 | ue_Map11>                              | <   | TX_Qι                | ueue_Map10           |  |  |  |  |
| 31   | 28                     | 27 24                                  | 23  | 20                   | 0 19                 |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-Bh                                 |     | R/W-0h               | R/W-Ah               |  |  |  |  |
| <    | TX_Que                 | eue_Map9>                              | <   | < TX_Queue_Map8      |                      |  |  |  |  |
| 15   | 12                     | 11 8                                   | 7   |                      | 4 3                  |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-9h                                 |     | R/W-0h               | R/W-8h               |  |  |  |  |
| тх_с | UEUE_CNTL3 - Address O | ffset 7ECh                             |     |                      |                      |  |  |  |  |
| <    | TX_Que                 | ue_Map15>                              | <   | TX_Qı                | ueue_Map14           |  |  |  |  |
| 31   | 28                     | 27 24                                  | 23  | 20                   | 0_19                 |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-Fh                                 |     | R/W-0h               | R/W-Eh               |  |  |  |  |
| <    | TX_Que                 | ue_Map13>                              | <   | TX_Qı                | ueue_Map12           |  |  |  |  |
| 15   | 12                     | 11 8                                   | 7   |                      | 4_3                  |  |  |  |  |
|      | Number of Msgs         | Queue Pointer                          |     | Number of Msgs       | Queue Pointer        |  |  |  |  |
|      | R/W-0h                 | R/W-Dh                                 |     | R/W-0h               | R/W-Ch               |  |  |  |  |

# Table 22. Weighted Round Robin Programming Registers (Address Offset 7E0h–7ECh)

|               | •                     |                |          |                                                                                                                     |
|---------------|-----------------------|----------------|----------|---------------------------------------------------------------------------------------------------------------------|
| Field Pair    | Register[Bits]        | Field          | Value    | Description                                                                                                         |
| TX_Queue_Map0 | TX_QUEUE_CNTL0[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL0[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map1.                        |
| TX_Queue_Map1 | TX_QUEUE_CNTL0[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|               | TX_QUEUE_CNTL0[15-12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map2.                        |

# Table 22. Weighted Round Robin Programming Registers (Address Offset 7E0h–7ECh) (continued)

| Field Pair     | Register[Bits]        | Field          | Value    | Description                                                                                                         |
|----------------|-----------------------|----------------|----------|---------------------------------------------------------------------------------------------------------------------|
| TX_Queue_Map2  | TX_QUEUE_CNTL0[19-16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL0[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map3.                        |
| TX_Queue_Map3  | TX_QUEUE_CNTL0[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL0[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map4.                        |
| TX_Queue_Map4  | TX_QUEUE_CNTL1[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL1[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map5.                        |
| TX_Queue_Map5  | TX_QUEUE_CNTL1[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL1[15–12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map6.                        |
| TX_Queue_Map6  | TX_QUEUE_CNTL1[19–16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL1[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map7.                        |
| TX_Queue_Map7  | TX_QUEUE_CNTL1[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL1[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map8.                        |
| TX_Queue_Map8  | TX_QUEUE_CNTL2[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL2[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map9.                        |
| TX_Queue_Map9  | TX_QUEUE_CNTL2[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL2[15–12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map10.                       |
| TX_Queue_Map10 | TX_QUEUE_CNTL2[19-16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL2[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map11.                       |

| Field Pair     | Register[Bits]        | Field          | Value    | Description                                                                                                         |
|----------------|-----------------------|----------------|----------|---------------------------------------------------------------------------------------------------------------------|
| TX_Queue_Map11 | TX_QUEUE_CNTL2[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL2[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map12.                       |
| TX_Queue_Map12 | TX_QUEUE_CNTL3[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL3[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map13.                       |
| TX_Queue_Map13 | TX_QUEUE_CNTL3[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL3[15–12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map14.                       |
| TX_Queue_Map14 | TX_QUEUE_CNTL3[19–16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL3[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map15.                       |
| TX_Queue_Map15 | TX_QUEUE_CNTL3[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL3[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map0.                        |

#### Table 22. Weighted Round Robin Programming Registers (Address Offset 7E0h–7ECh) (continued)

The TX queues are treated differently than the RX queues. A TX queue can mix single and multi-segment message buffer descriptors. The software manages the queue usage.

All outgoing message segments have responses that indicate the status of the transaction. Responses may indicate DONE, ERROR or RETRY. A buffer descriptor may be released back to CPU control (OWNERSHIP = 0), only after all segment responses are received, or alternatively if a response timeout occurs. Timeouts and response evaluation have high priority in the state-machine since they are the only means to release TX packet resources. The CC is set in the buffer descriptor to indicate the response status to the CPU. If there is a RETRY response, the TX CPPI module will immediately retry the packet before continuing to the next queue in the round-robin loop, as long as the RETRY\_COUNT is not exceeded. Once this limit is exceeded, the buffer can be released back to CPU control with the appropriate CC set. Retry of a message segment does not imply retrying a whole message. Only segments for which a RETRY response is received should be re-transmitted. This will involve calculating the correct starting point within the TX data buffer based on the failed segment number and message length. To achieve respectable performance, the peripheral must not wait for a message/segment response before sending out the next packet.

Since RapidIO allows for out-of-order responses, the TX CPPI hardware must support this functionality. As responses are received, the hardware updates the corresponding TX buffer descriptor to reflect the status. However, if the response is out-of-order, the hardware does not update the CP or set the corresponding interrupt. Only after all preceding outstanding message responses are received, will the CP and interrupt be updated. This ensures that a contiguous block of buffer descriptors, starting at the oldest outstanding descriptor, has been processed by the hardware and is ready for the CPU to reclaim the buffers.

A transaction timeout is used by all outgoing message and direct I/O packets. It has the same value and is analogous to the request-to-response timer discussed in the RX CPPI and LSU sections, which is defined by the 24-bit value in the port response time-out CSR (See Section 2.3.3.3). The *RapidIO Interconnect Specification* states that the maximum time interval (all 1s) is between 3 and 6 seconds. A logical layer timeout occurs if the response packet is not received before a countdown timer (initialized to this CSR value) reaches zero. Since transaction responses can be acknowledged out-of-order, a timer is needed for each supported outstanding packet in the TX queue. Each outstanding packet response timer requires a 4-bit register. The register is loaded with the current timecode when the transaction is sent. Each time the timecode changes, a 4-bit compare is done to the 16 outstanding packet registers. If the register becomes equal to the timecode again, without a response being seen, then the transaction has timed out and the buffer descriptor is written.

Essentially, instead of the 24-bit value representing the period of the response timer, the period is now defined as  $P = (2^{24} \times 16)/F$ . This means the countdown timer frequency needs to be 44.7–89.5 MHz for a 6–3 second response timeout. Since the needed timer frequency is derived from the DMA bus clock (which is device dependent), the hardware supports a programmable configuration register field to properly scale the clock frequency. This configuration register field is described in the Peripheral Setting Control register (Address offset 0020h).

The CPU initiates a TX queue teardown by writing to the TX Queue Teardown command register. Teardown of a TX queue will cause the following actions:

- No new messages will be sent.
- All messages (single and multi-segment) already started will be completed.
  - Failing to complete the message TX would leave an active receiver blocked waiting for the final segments until the transaction eventually times-out.
  - Note that normal TX State Machine operation is to not send any more segments once an error response has been received on any segment. So if the receiver has also been torn-down (and is receiving error responses) multi-segment transmit will complete as soon as all in-transit segments have been responded to.
- When all in-transit messages/segments have been responded to, teardown will be completed as follows:
  - If the queue is active, the teardown bit will be set in the next buffer descriptor in the queue. The
    peripheral completes the teardown procedure by clearing the HDP register, setting the CP register
    to FFFFFFCh, and issuing an interrupt for the given queue. The teardown command register bit is
    automatically cleared by the peripheral.
  - If the queue is in-active (no additional buffer descriptors available), or becomes inactive after a
    message in transmission is completed, no buffer descriptor fields are written. The HDP register and
    the CP register remain unchanged. An interrupt is not issued. The teardown command register bit
    is automatically cleared by the peripheral.
  - Because of topology differences between flow's response, packets may arrive in a different order to the order of requests.

After the teardown process is complete and the interrupt is serviced by the CPU, software must re-initialize the TX queue to restart normal operation.

#### 2.3.4.3 Reset and Power Down State

Upon reset, the CPPI module must be configured by the CPU. The CPU sets up the receive and transmit queues in memory. Then the CPU updates the CPPI module with the appropriate RX/TX DMA state head descriptor pointer, so the peripheral knows with which buffer descriptor address to start. Additionally, the CPU must provide the CPPI module with initial buffer descriptor values for each data buffer.

The CPPI module can be powered down if the message passing protocol is not being supported in the application. For example, if the direct I/O protocol is being used for data transfers, powering down the CPPI module will save power. In this situation, the buffer descriptor queue SRAMs and mailbox mapper logic should be powered down. Clocks should be gated to these blocks while in the power down state. Section 2.3.10 describes this in detail.



#### 2.3.4.4 Message Passing Software Requirements

Software performs the following functions for messaging:

### **RX** Operation

- Assigns Mailbox-to-queue mapping and allowable SourceIDs/mailbox- Queue Mapping
- Sets up associated buffer descriptor memory CPPI RAM or L2 RAM
- Link-lists the buffer descriptors, next\_descriptor\_pointer
- Assigns single segment (256-byte payload) and multi-segment (4K-byte payload) buffers to queues buffer\_length
- Assigns buffer descriptor to data buffer, buffer\_pointer
- Gives control of the buffer to the peripheral, ownership = 1

Configures and initiates RX queues

- Assigns Head Descriptor Pointer, HDP, for up to 16 queues: RX DMA State HDP
- Port begins to consume buffers beginning with HDP descriptor and sets ownership = 0 for each buffer descriptor used. Writes Completion Pointer, CP, RX DMA State CP and moves to next buffer.
- Port hardware generates pending interrupt when CP is written. Physical interrupt generated when Interrupt Pacing Count down timer = 0.

#### Processes interrupt

- Determines ICSR bit and process corresponding queue until ownership = 1 or eoq = 1
- Sets processed buffer descriptor ownership = 1
- Writes CP value of last buffer descriptor processed
- Port hardware clears ICSR bit only if the CP value written by CPU equals port written value in the RX DMA State CP register
- Resets interrupt pacing value

#### **TX Operation**

Sets up associated buffer descriptor memory - CPPI RAM or L2 RAM

- Link-lists the buffer descriptors, next\_descriptor\_pointer
- Assigns buffer descriptor to data buffer, buffer\_pointer
- CPU writes buffer descriptors and sets ownership = 1 for each used.
- Specifies RIO fields: Dest\_id, Pri, tt, Mailbox
- Sets parameters: PortID, Message\_length
- Port starts queue transmit on CPU write to HDP for up to 16 queues TX DMA State HDP
- Port processes corresponding queues until ownership = 0 or next\_descriptor\_pointer = all 0s. Port sets eoq = 1 and writes all 0s to the HDP.
- When each packet transmission is complete, the port sets ownership = 0 and issues an interrupt to the CPU by writing the last processed buffer descriptor address to the CP, TX DMA State CP

#### Processes interrupt

- The CPU processes the buffer queue to reclaim buffers. If ownership = 0, the packet has been transmitted and the buffer is reclaimed.
- CPU processes the queue until eoq = 1 or ownership = 1
- CPU determines all packets have been transmitted if ownership = 0, eoq = 1, and next\_descriptor\_pointer = all 0s in last processed buffer descriptor
- CPU acknowledges the interrupt after re-claiming all available buffer descriptors.
- CPU acknowledges the interrupt by writing the CP value
- This value is compared against the port written value in the TX DMA State CP register, if equal, the interrupt is deasserted.



#### Initialization Example

| SRIO_REGS->Queue0_RXDMA_HDP  | = | 0 |
|------------------------------|---|---|
| SRIO_REGS->Queue1_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue2_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue3_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue4_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue5_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue6_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue7_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue8_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue9_RXDMA_HDP  | = | 0 |
| SRIO_REGS->Queue10_RXDMA_HDP | = | 0 |
| SRIO_REGS->Queue11_RXDMA_HDP | = | 0 |
| SRIO_REGS->Queue12_RXDMA_HDP | = | 0 |
| SRIO_REGS->Queue13_RXDMA_HDP | = | 0 |
| SRIO_REGS->Queue14_RXDMA_HDP | = | 0 |
| SRIO_REGS->Queue15_RXDMA_HDP | = | 0 |

:

#### **Queue Mapping**

```
SRIO_REGS->RXU_MAP01_L = CSL_FMK( SRIO_RXU_MAP01_L_LETTER_MASK, 3)|
CSL_FMK( SRIO_RXU_MAP01_L_MAILBOX_MASK, 0x3F)
CSL_FMK( SRIO_RXU_MAP01_L_LETTER, 0)
CSL_FMK( SRIO_RXU_MAP01_L_MAILBOX, 1)
CSL_FMK( SRIO_RXU_MAP01_L_SOURCEID, 0xBEEF);
SRIO_REGS->RXU_MAP01_H = CSL_FMK( SRIO_RXU_MAP01_H_TT, 1)
CSL_FMK( SRIO_RXU_MAP01_H_OUEUE_ID, 0)
CSL_FMK( SRIO_RXU_MAP01_H_PROMISCUOUS, 1)|
CSL_FMK( SRIO_RXU_MAP01_H_SEGMENT_MAPPING, 1);
```

#### **RX Buffer Descriptor**

RX\_DESCP0\_0->RXDESC0 = CSL\_FMK( SRIO\_RXDESC0\_N\_POINTER,(int )RX\_DESCP0\_1 ); //link to RX\_DESCP0\_1 RX\_DESCP0\_0->RXDESC1 = CSL\_FMK( SRIO\_RXDESC1\_B\_POINTER,(int )&rcvBuff1[0] ); RX\_DESCP0\_0->RXDESC2 = CSL\_FMK( SRIO\_RXDESC2\_SRC\_ID, 0xBEEF) | CSL\_FMK( SRIO\_RXDESC2\_PRI, 1) CSL\_FMK( SRIO\_RXDESC2\_TT, 1) CSL\_FMK( SRIO\_RXDESC2\_MAILBOX, 0); RX\_DESCP0\_0->RXDESC3 = CSL\_FMK( SRIO\_RXDESC3\_SOP,1 ) CSL\_FMK( SRIO\_RXDESC3\_EOP,1 ) CSL\_FMK( SRIO\_RXDESC3\_OWNERSHIP,1 ) CSL\_FMK( SRIO\_RXDESC3\_EOQ,1 ) CSL\_FMK( SRIO\_RXDESC3\_TEARDOWN,0 ) CSL\_FMK( SRIO\_RXDESC3\_CC,0 ) CSL\_FMK( SRIO\_RXDESC3\_MESSAGE\_LENGTH, MLEN\_512DW); RX\_DESCP0\_1->RXDESC0 = CSL\_FMK( SRIO\_RXDESC0\_N\_POINTER, 0); //end of message RX\_DESCP0\_1->RXDESC1 = CSL\_FMK( SRIO\_RXDESC1\_B\_POINTER,(int )&rcvBuff2[0] ); RX\_DESCP0\_1->RXDESC2 = CSL\_FMK( SRIO\_RXDESC2\_SRC\_ID, 0xBEEF) | CSL\_FMK( SRIO\_RXDESC2\_PRI, 1) CSL\_FMK( SRIO\_RXDESC2\_TT, 1) CSL\_FMK( SRIO\_RXDESC2\_MAILBOX, 1); RX\_DESCP0\_1->RXDESC3 = CSL\_FMK( SRIO\_RXDESC3\_SOP,1 ) CSL FMK( SRIO RXDESC3 EOP,1 ) CSL\_FMK( SRIO\_RXDESC3\_OWNERSHIP,1 ) CSL\_FMK( SRIO\_RXDESC3\_EOQ,1 ) CSL\_FMK( SRIO\_RXDESC3\_TEARDOWN,0 ) CSL\_FMK( SRIO\_RXDESC3\_CC,0 ) CSL\_FMK( SRIO\_RXDESC3\_MESSAGE\_LENGTH, MLEN\_512DW );



# Figure 24. RX Buffer Descriptors



#### **TX Buffer Descriptor**

```
TX_DESCP0_0->TXDESC0 = CSL_FMK( SRI0_TXDESC0_N_POINTER,(int )TX_DESCP0_1 );
                                                                              //link to
TX_DESCP0_1
TX_DESCP0_0->TXDESC1 = CSL_FMK( SRIO_TXDESC1_B_POINTER,(int )&xmtBuff1[0] );
                                                                                      //Buffer
Pointer
TX_DESCP0_0->TXDESC2 = CSL_FMK( SRIO_TXDESC2_DESTID, 0xBEEF)
                        CSL_FMK( SRIO_TXDESC2_PRI, 1)
                        CSL_FMK( SRIO_TXDESC2_TT, 1)
                        CSL_FMK( SRIO_TXDESC2_PORTID, 3)
                        CSL_FMK( SRIO_TXDESC2_SSIZE, SSIZE_256B)
                        CSL_FMK( SRIO_TXDESC2_MAILBOX, 0);
TX_DESCP0_0->TXDESC3 = CSL_FMK( SRIO_TXDESC3_SOP,1 )
                        CSL FMK( SRIO TXDESC3 EOP,1 )
                        CSL_FMK( SRIO_TXDESC3_OWNERSHIP,1 )
                        CSL_FMK( SRIO_TXDESC3_EOQ,1 )
                        CSL_FMK( SRIO_TXDESC3_TEARDOWN,0 )
                        CSL_FMK( SRIO_TXDESC3_RETRY_COUNT,0 ) |
                        CSL_FMK( SRIO_TXDESC3_MESSAGE_LENGTH, MLEN_512DW );
TX_DESCP0_1->TXDESC0 = CSL_FMK( SRIO_TXDESC0_N_POINTER, 0);
                                                                      //end of message
TX_DESCP0_1->TXDESC1 = CSL_FMK( SRIO_TXDESC1_B_POINTER,(int )&xmtBuff2[0] );
TX_DESCP0_1->TXDESC2 = CSL_FMK( SRIO_TXDESC2_DESTID, 0xBEEF)
                        CSL_FMK( SRIO_TXDESC2_PRI, 1)
                        CSL_FMK( SRIO_TXDESC2_TT, 1)
                        CSL_FMK( SRIO_TXDESC2_PORTID, 3)
                        CSL_FMK( SRIO_TXDESC2_SSIZE, SSIZE_256B)
                        CSL_FMK( SRIO_TXDESC2_MAILBOX, 1);
TX_DESCP0_1->TXDESC3 = CSL_FMK( SRIO_TXDESC3_SOP,1 )
                        CSL_FMK( SRIO_TXDESC3_EOP,1 )
                        CSL_FMK( SRIO_TXDESC3_OWNERSHIP,1 )
                        CSL_FMK( SRIO_TXDESC3_EOQ,1 )
                        CSL_FMK( SRIO_TXDESC3_TEARDOWN,0 )
                        CSL_FMK( SRIO_TXDESC3_RETRY_COUNT,0 )
                        CSL_FMK( SRIO_TXDESC3_MESSAGE_LENGTH, MLEN_512DW );
```



### Figure 25. TX Buffer Descriptors

#### Start Message Passing

| SRIO_REGS->Queue0_RXDMA_HDP | = (int )RX_DESCP0_0 ; |
|-----------------------------|-----------------------|
| SRIO_REGS->Queue0_TXDMA_HDP | = (int )TX_DESCP0_0 ; |

### 2.3.5 Maintenance

The type 8 MAINTENANCE packet format accesses the RapidIO capability registers (CARs), command and status registers (CSRs), and data structures. Unlike other request formats, the type 8 packet format serves as both the request and the response format for maintenance operations. Type 8 packets contain no addresses and only contain data payloads for write requests and read responses. All configuration register read accesses are word (4-byte) accesses. All configuration register write accesses are also word (4-byte) accesses.

The wrsize field specifies the maximum size of the data payload for multiple double-word transactions. The data payload may not exceed that size but may be smaller if desired. Both the maintenance read and the maintenance write request generate the appropriate maintenance response.

The maintenance port-write operation is a write operation that does not have guaranteed delivery and does not have an associated response. This maintenance operation is useful for sending messages such as error indicators or status information from a device that does not contain an endpoint, such as a switch. The data payload is typically placed in a queue in the targeted endpoint and an interrupt is typically generated to a local processor. A port-write request to a queue that is full or busy servicing another request may be discarded.

```
SRIO_REGS->LSU1_REG0 = CSL_FMK( SRIO_LSU1_REG0_RAPIDIO_ADDRESS_MSB,0 );
SRIO_REGS->LSU1_REG1 = CSL_FMK( SRIO_LSU1_REG1_ADDRESS_LSB_CONFIG_OFFSET, (int )car_csr );
SRIO_REGS->LSU1_REG2 = CSL_FMK( SRIO_LSU1_REG2_DSP_ADDRESS, (int )&xmtBuff[0]);
SRIO_REGS->LSU1_REG3 = CSL_FMK( SRIO_LSU1_REG3_BYTE_COUNT,byte_count );
SRIO_REGS->LSU1_REG4 = CSL_FMK( SRIO_LSU1_REG4_OUTPORTID,0 )
CSL_FMK( SRIO_LSU1_REG4_PRIORITY,0 )
CSL_FMK( SRIO_LSU1_REG4_PRIORITY,0 )
CSL_FMK( SRIO_LSU1_REG4_LD_SIZE,1 )
CSL_FMK( SRIO_LSU1_REG4_DESTID,0xBEEF )
CSL_FMK( SRIO_LSU1_REG4_INTERRUPT_REQ,0 );
SRIO_REGS->LSU1_REG5 = CSL_FMK( SRIO_LSU1_REG5_DRBLL_INFO,0x0000 )
CSL_FMK( SRIO_LSU1_REG5_HOP_COUNT,0x03 )
CSL_FMK( SRIO_LSU1_REG5_PACKET_TYPE,type ); //type = REQ_MAINT_RD
```

#### 2.3.6 Doorbell Operation

The doorbell operation is shown in Figure 26. It consists of the DOORBELL and RESPONSE transactions (typically a DONE response), and it is used by a processing element to send a very short message to another processing element through the interconnect fabric. The DOORBELL transaction contains the info field to hold information and does not have a data payload. This field is software-defined and can be used



for any desired purpose; see the *RapidIO Interconnect Specification*, Section 3.1.4, *Type 10 Packet Formats (Doorbell Class)*, for information about the info field. A processing element that receives a doorbell transaction takes the packet and puts it in a doorbell message queue within the processing element. This queue may be implemented in hardware or in local memory. This behavior is similar to that of typical message passing mailbox hardware. The local processor is expected to read the queue to determine the sending processing element and the info field, and determine what action to take.

The DOORBELL functionality is user-defined, but this packet type is commonly used to initiate DSP core (CPU) interrupts. A DOORBELL packet is not associated with a particular data packet that was previously transferred, so the info field of the packet must be configured to reflect the DOORBELL bit to be serviced for the correct TID (Transfer Information Descriptor) information to be processed.



The DOORBELL packet's 16-bit INFO field indicates which DOORBELL register interrupt bit to set. There are four DOORBELL registers, each currently with 16 bits, allowing 64 interrupt sources or circular buffers (see Table 23). Each bit can be assigned to any core as described below by the Interrupt Condition Routing Registers. Additionally, each status bit is user-defined for the application. For instance, it may be desirable to support multiple priorities with multiple TID circular buffers per core if control data uses a high priority (for example, priority = 2), while data packets are sent on priority 0 or 1. This allows the control packets to have preference in the switch fabric and arrive as quickly as possible. Since it may be required to interrupt the CPU for both data and control packet processing separately, separate circular buffers are used, and DOORBELL packets need to distinguish between them for interrupt servicing. If any reserved bit in the DOORBELL info field is set, an error response is sent.

|           |                   |      | •               |                                        | •                                                | •                                                  |
|-----------|-------------------|------|-----------------|----------------------------------------|--------------------------------------------------|----------------------------------------------------|
| inf       | o Field Segm      | ents |                 | Value Written To                       |                                                  |                                                    |
| Reserved  | Doorbell<br>Reg # | rsv  | Doorbell<br>Bit | DOORBELL_INFO<br>Field Of<br>LSUn_REG5 | Associated<br>Doorbell Interrupt<br>Routing Bits | Mapped To This<br>Doorbell Interrupt<br>Status Bit |
| 00000000b | 00b               | 0b   | 0000b           | 0000h                                  | DOORBELL0_ICRR[3:0]                              | DOORBELL0_ICSR[0]                                  |
| 00000000b | 00b               | 0b   | 1001b           | 0009h                                  | DOORBELL0_ICRR2[7:4]                             | DOORBELL0_ICSR[9]                                  |
| 00000000b | 01b               | 0b   | 0111b           | 0027h                                  | DOORBELL1_ICRR[31:28]                            | DOORBELL1_ICSR[7]                                  |
| 00000000b | 01b               | 0b   | 1100b           | 002Ch                                  | DOORBELL1_ICRR2[19:16]                           | DOORBELL1_ICSR[12]                                 |
| 00000000b | 10b               | 0b   | 0101b           | 0045h                                  | DOORBELL2_ICRR[23:20]                            | DOORBELL2_ICSR[5]                                  |
| 00000000b | 10b               | 0b   | 1111b           | 004Fh                                  | DOORBELL2_ICRR2[31:28]                           | DOORBELL2_ICSR[15]                                 |
| 00000000b | 11b               | 0b   | 0110b           | 0066h                                  | DOORBELL3_ICRR[27:24]                            | DOORBELL3_ICSR[6]                                  |
| 00000000b | 11b               | 0b   | 1011b           | 006Bh                                  | DOORBELL3_ICRR2[15:12]                           | DOORBELL3_ICSR[11]                                 |

| Table 23 Examples of DOORBELL   | INFO Designations (See Figure 26)    |  |
|---------------------------------|--------------------------------------|--|
| Table 23. LABINDIES OF DOUNDLLL | INI O Designations (See 1 igure 20 ) |  |

```
SRIO_REGS->LSU1_REG0 = CSL_FMK( SRIO_LSU1_REG0_RAPIDIO_ADDRESS_MSB,0 );
SRIO_REGS->LSU1_REG1 = CSL_FMK( SRIO_LSU1_REG1_ADDRESS_LSB_CONFIG_OFFSET, 0);
SRIO_REGS->LSU1_REG2 = CSL_FMK( SRIO_LSU1_REG2_DSP_ADDRESS, 0);
SRIO_REGS->LSU1_REG3 = CSL_FMK( SRIO_LSU1_REG3_BYTE_COUNT, 0 );
SRIO_REGS->LSU1_REG4 = CSL_FMK( SRIO_LSU1_REG4_OUTPORTID,1 ) |
CSL_FMK( SRIO_LSU1_REG4_PRIORITY,0 ) |
CSL_FMK( SRIO_LSU1_REG4_PRIORITY,0 ) |
CSL_FMK( SRIO_LSU1_REG4_ID_SIZE,1 ) |
CSL_FMK( SRIO_LSU1_REG4_DESTID,0XBEEF ) |
CSL_FMK( SRIO_LSU1_REG4_INTERRUPT_REQ,0 );
SRIO_REGS->LSU1_REG5 = CSL_FMK( SRIO_LSU1_REG5_DRBLL_INFO,0x0000 ) |
CSL_FMK( SRIO_LSU1_REG5_HOP_COUNT,0x03 ) |
CSL_FMK( SRIO_LSU1_REG5_PACKET_TYPE,type );//type = DOORBELL
```

#### 2.3.7 Atomic Operations

The Atomic operation is a combination read and write operation. The destination reads the data at the specified address, returns the read data to the requestor, performs the required operation to the data, and then writes the modified data back to the specified address without allowing any intervening activity to that address. Defined operations are increment, decrement, test-and-swap, set, and clear (see Table 3, *Packet Type*). Of these, only test-and-swap requires the requesting processing element to supply data. Incoming Atomic operations which target the device are not supported for internal L2 memory or registers. Atomic request operations to external devices are supported and have a response packet.

Request Atomic operations (Ftype 2) never contain a data payload. These operations are like NREAD (24h) transactions. The data payload size for the response to an Atomic transaction is 8 bytes. The addressing scheme defined for the read portion of the Atomic transaction also controls the size of the atomic operation in memory so that the bytes are contiguous and of size byte, half-word (2 bytes), or word (4 bytes), and are aligned to that boundary and byte lane as with a regular read transaction. Double-word (8-byte), 3-byte, 5-byte, 6-byte, and 7-byte Atomic transactions are not allowed.

Atomic test-and-swap operations (Ftype 5) to external devices are limited to a payload of one double-word (8 bytes). These operations are like NWRITE with response (55h) transactions. The addressing scheme defined for the write transactions also controls the size of the Atomic operation in memory so that the bytes are contiguous and of size byte, half-word (2 bytes), or word (4 bytes), and are aligned to that boundary and byte lane as with a regular write transaction. Double-word (8-byte), 3-byte, 5-byte, 6-byte, and 7-byte Atomic test-and-swap transactions are not allowed. Upon receipt of the request, the targeted device swaps the contents of the specified memory location and the payload if the contents of the memory location are returned, and the appropriate completion code is set in the LSU status register (LSU*n*\_REG6). The completion codes are listed in Table 15.

#### 2.3.8 Congestion Control

The RapidIO *Logical Layer Flow Control Extensions Specification*. This section describes the requirements and implementation of congestion control within the peripheral.

The peripheral is notified of switch fabric congestion through type 7 RapidIO packets. The packets are referred to as Congestion Control Packets (CCPs). The purpose of these packets is to turn off (Xoff), or turn on (Xon) specific flows defined by DESTID and PRIORITY of outgoing packets. CCPs are sent at the highest priority in an attempt to address fabric congestion as quickly as possible. CCPs do not have a response packet and they do not have guaranteed delivery.

When the peripheral receives an Xoff CCP, the peripheral must block outgoing LSU and CPPI packets that are destined for that flow. When the peripheral receives an Xon, the flow may be enabled. Since CCPs may arrive from different switches within the fabric, it is possible to receive multiple Xoff CCPs for the same flow. For this reason, the peripheral must maintain a table and count of Xoff CCPs for each flow. For example, if two Xoff CCPs are received for a given flow, two Xon CCPs must be received before the flow is enabled.



#### SRIO Functional Description

Since CCPs do not have guaranteed delivery and can be dropped by the fabric, an implicit method of enabling an Xoff'd flow must exist. A simple timeout method is used. Additionally, flow control checks can be enabled or disabled through the Transmit Source Flow Control Masks. Received CCPs are not passed through the DMA bus interface.

#### 2.3.8.1 Detailed Description

To avoid large and complex table management, a basic scheme is implemented for congestion management. The primary goal is to avoid large parallel searches of a centralized congested route table for each outgoing packet request. The congested route table requirements and subsequent searches would be overwhelming if each possible DESTID and PRIORITY combination had its own entry. To implement a more basic scheme, the following assumptions have been made:

- A small number of flows constitute the majority of traffic, and these flows are most likely to cause congestion
- HOL blocking is undesired, but allowable for TX CPPI queues
- Flow control will be based on DESTID only, regardless of PRIORITY

The congested route table is therefore more static in nature. Instead of dynamically updating a table with each CCP's flow information as it arrives, a small finite-entry table is set up and configured by software to reflect the more critical flows it is using. Only these flows have a discrete table entry. A 16 entry table reflects 15 critical flows, leaving the sixteenth entry for general other flows, which are categorized together. Figure 27 and Table 24 summarize the DESTID table entries that are programmable by the CPU through dedicated flow control registers. A 3-bit hardware counter is implemented for table entries 0 through 14, to maintain a count of Xoff CCPs for that flow. The other flows table entry counts Xoff CCPs for all flows other than the discrete entries. The counter for this table entry has 5 bits. All outgoing flows with non-zero Xoff counts are disabled. The counter value is decremented for each corresponding Xon CCP that is received, but it is not decrement below zero. Additionally, a hardware timer exists for each table entry to turn on flows that may have been abandoned by lost Xon CCPs. The timer value is of an order of magnitude larger than the 32-bit Port Response Time-out CSR value. For this reason, each transmission source adds 2 bits to its 4-bit response time-out counter. Descriptions of this type of time-out counter are in Section 2.3.3.3 and Section 2.3.4.2. The additional 2 bits count three timecode revolutions and provide an implicit Xon timer equal to 3x the Response time-out counter value.

#### Figure 27. Flow Control Table Entry Registers (Address Offset 0900h–093Ch)

|            | 31-18                 | 17-16        | 15-0                       |
|------------|-----------------------|--------------|----------------------------|
| FLOW_CNTL0 | Reserved              | TT           | FLOW_CNTL_ID               |
|            | R-0x00000             | R/W-01       | R/W-0x0000                 |
|            | 31-18                 | 17-16        | 15-0                       |
| FLOW_CNTL1 | Reserved              | TT           | FLOW_CNTL_ID               |
|            | R-0x00000             | R/W-01       | R/W-0x0000                 |
|            |                       |              |                            |
|            | 31-18                 | 17-16        | 15-0                       |
| FLOW_CNTL2 | 31-18<br>Reserved     | 17-16<br>TT  | 15-0<br>FLOW_CNTL_ID       |
| FLOW_CNTL2 |                       |              |                            |
| FLOW_CNTL2 | Reserved              | TT           | FLOW_CNTL_ID               |
| FLOW_CNTL2 | Reserved              | TT           | FLOW_CNTL_ID               |
| FLOW_CNTL2 | Reserved<br>R-0x00000 | TT<br>R/W-01 | FLOW_CNTL_ID<br>R/W-0x0000 |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

| Bit   | Field        | Value       | Description                                                                                                                 |
|-------|--------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31–18 | Reserved     | 0           | These read-only bits return 0s when read.                                                                                   |
| 17–16 | TT           |             | Transfer type for flow n                                                                                                    |
|       |              | 00b         | 8-bit destination IDs                                                                                                       |
|       |              | 01b         | 16-bit destination IDs                                                                                                      |
|       |              | 1xb         | Reserved                                                                                                                    |
| 15–0  | FLOW_CNTL_ID | 0000h-FFFFh | Destination ID for flow $n$ . When 8-bit destination IDs are used (TT = 00b), the 8 MSBs of this field are don't care bits. |

#### Table 24. Flow Control Table Entry Register *n* (FLOW\_CNTL*n*) Field Descriptions

Each transmit source, including any LSU and any TX CPPI queue, indicates which of the 16 flows it uses with a 16-bit flow mask. Figure 28 illustrates the registers that contain the flow masks, and Figure 29 illustrates the general form of an individual flow mask. As can be seen from Table 25, bits 0 through 15 of the flow mask correspond to flows 0 through 15, respectively.

The CPU must configure the flow masks upon reset. The default setting is all 1s, indicating that the transmit source supports all flows. If the register is set to all 0s, the transmit source does not support any flow, and consequently, that source is never flow-controlled. If any of the table entry counters that a transmit source supports have a corresponding non-zero Xoff count, the transmit source is flow-controlled. A simple 16-bit bus indicates the Xoff state of all 16 flows and is compared to the transmit source mask register. Each source interprets this result and performs flow control accordingly. For example, an LSU module that is flow-controlled can reload its registers and attempt to send a packet to another flow, while a TX CPPI queue that is flow-controlled may create HOL blocking issues on that queue.



### Figure 28. Transmit Source Flow Control Masks

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

|       | Figure 20. Fields Within Lach Flow Mask |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
|-------|-----------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 15    | 14                                      | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| FL15  | FL14                                    | FL13  | FL12  | FL11  | FL10  | FL9   | FL8   | FL7   | FL6   | FL5   | FL4   | FL3   | FL2   | FL1   | FL0   |
| R/W-1 | R/W-1                                   | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|       |                                         |       |       |       |       |       |       |       |       |       |       |       |       |       |       |

# Figure 29. Fields Within Each Flow Mask

LEGEND: R/W = Read/Write; -n = Value after reset



#### Table 25. Fields Within Each Flow Mask Description Bit Field Value 15 FL15 0 TX source does not support Flow 15 from table entry 1 TX source supports Flow 15 from table entry 14 **FL14** 0 TX source does not support Flow 14 from table entry 1 TX source supports Flow 14 from table entry 13 FL13 0 TX source does not support Flow 13 from table entry 1 TX source supports Flow 13 from table entry FL12 0 12 TX source does not support Flow 12 from table entry 1 TX source supports Flow 12 from table entry 11 **FL11** 0 TX source does not support Flow 11 from table entry 1 TX source supports Flow 11 from table entry 10 FL10 0 TX source does not support Flow 10 from table entry 1 TX source supports Flow 10 from table entry 9 FL9 0 TX source does not support Flow 9 from table entry 1 TX source supports Flow 9 from table entry 8 FL8 0 TX source does not support Flow 8 from table entry 1 TX source supports Flow 8 from table entry 7 FL7 0 TX source does not support Flow 7 from table entry 1 TX source supports Flow 7 from table entry 6 FL6 0 TX source does not support Flow 6 from table entry 1 TX source supports Flow 6 from table entry 5 FL5 0 TX source does not support Flow 5 from table entry 1 TX source supports Flow 5 from table entry 4 FL4 0 TX source does not support Flow 4 from table entry 1 TX source supports Flow 4 from table entry 3 FL3 0 TX source does not support Flow 3 from table entry 1 TX source supports Flow 3 from table entry 2 FL2 0 TX source does not support Flow 2 from table entry 1 TX source supports Flow 2 from table entry FL1 0 TX source does not support Flow 1 from table entry 1 1 TX source supports Flow 1 from table entry 0 FL0 0 TX source does not support Flow 0 from table entry 1 TX source supports Flow 0 from table entry

#### 2.3.9 Endianness

RapidIO is based on Big Endian. This is discussed in detail in Section 2.4 of the *RapidIO Interconnect Specification*. Essentially, Big Endian specifies the address ordering as the most significant bit/byte first. For example, in the 29-bit address field of a RapidIO packet (shown in Figure 6) the left-most bit that is transmitted first in the serial bit stream is the MSB of the address. Likewise, the data payload of the packet is double-word aligned Big Endian, which means the MSB is transmitted first. Bit 0 of all the RapidIO-defined MMR registers is the MSB.

All Endian-specific conversion is handled within the peripheral. For double-word aligned payloads, the data should be written contiguously into memory beginning at the specified address. Any unaligned payloads will be padded and properly aligned within the 8-byte boundary. In this case, WDPTR, RDSIZE, and WRSIZE RapidIO header fields indicate the byte position of the data within the double-word boundary. An example of an unaligned transfer is shown in Section 2.4 of the *RapidIO Interconnect Specification*.

# 2.3.9.1 Translation for MMR space

There are no Endian translation requirements for accessing the local MMR space. Regardless of the device memory Endian configuration, all configuration bus accesses are performed on 32-bit values at a fixed address position. The bit positions in the 32-bit word are defined by this specification. This means that a memory image which will be copied to a MMR is identical between Little Endian and Big Endian configurations. Configuration bus reads are performed in the same manner. Figure 30 illustrates the concept. The desired operation is to locally update a serial RapidIO MMR (offset 1000h) with a value of A0A1A2A3h, using the configuration bus.





When accessing RapidIO defined MMR within an external device, RapidIO allows 4 bytes, 8 bytes, or any multiple of a double-word access (up to 64 bytes) for type 8 (maintenance) packets. The peripheral only supports 4-byte accesses as the target, but can generate all sizes of request packets. RapidIO is defined as Big Endian only, and has double-word aligned Big Endian packet payloads.

# 2.3.9.2 Endian Conversion (TMS320TCI6482)

The DMA, however, supports byte wide accesses. The peripheral performs Endian conversion on the payload if Little Endian is used on the device. This conversion is not only applicable for type 8 packets, but is also relevant for all outgoing payloads of NWRITE, NWRITE\_R, SWRITE, NREAD, and message packets. This means that the memory image is different between Little Endian and Big Endian configurations, as shown in Figure 31.

# Figure 31. DMA Example

The desired operation is to send a Type 8 maintenance request to an external device. The goal is to read 16B of RapidIO MMR from an external device, starting offset 0x0000. This operation involves the LSU block and utilizes the DMA for transferring the response packet payload.



#### 2.3.10 Reset and Power Down

The RapidIO peripheral allows independent software controlled shutdown for the logical blocks listed in Table 26. With the exception of BLK0\_EN for the memory-mapped registers (MMRs), when the BLK*n*\_EN signals are deasserted, the clocks are gated to these blocks, effectively providing a shutdown function.

| Logical Block                                          | Bus<br>Reset | GBL<br>_EN   | BLK0<br>_EN  | BLK1<br>_EN  | BLK2<br>_EN  | BLK3<br>_EN | BLK4<br>_EN | BLK5<br>_EN | BLK6<br>_EN  | BLK7<br>_EN  | BLK8<br>_EN  |
|--------------------------------------------------------|--------------|--------------|--------------|--------------|--------------|-------------|-------------|-------------|--------------|--------------|--------------|
| DMA interface                                          | $\checkmark$ |              | _            | _            | _            | _           | _           | _           | _            | _            | _            |
| MMRs:<br>Reset/power-<br>down control<br>registers     | V            | V            |              |              |              |             |             |             |              |              |              |
| MMRs:<br>Non-reset/power-<br>down control<br>registers |              | V            | $\checkmark$ |              |              |             |             |             |              |              |              |
| Interrupt handling unit (IHU)                          |              |              |              |              |              |             |             |             |              |              |              |
| Traffic flow logic                                     |              |              |              |              |              |             |             |             |              |              |              |
| Congestion<br>control unit<br>(CCU)                    | $\checkmark$ | V            |              |              |              |             |             |             |              |              |              |
| LSU (Direct I/O initiator)                             |              |              |              | $\checkmark$ |              |             |             |             |              |              |              |
| MAU (Direct I/O target)                                | $\checkmark$ | $\checkmark$ |              |              | $\checkmark$ |             |             |             |              |              |              |
| TXU (message passing initiator)                        | $\checkmark$ |              |              |              |              | V           |             |             |              |              |              |
| RXU (message passing target)                           | $\checkmark$ |              |              |              |              |             | V           |             |              |              |              |
| Port 0 datapath                                        | $\checkmark$ |              |              |              |              |             |             |             |              |              |              |
| Port 1 datapath                                        | $\checkmark$ |              |              |              |              |             |             |             | $\checkmark$ |              |              |
| Port 2 datapath                                        | $\checkmark$ |              |              |              |              |             |             |             |              | $\checkmark$ |              |
| Port 3 datapath                                        | $\checkmark$ |              |              |              |              |             |             |             |              |              | $\checkmark$ |

Table 26. Reset Hierarchy

Reset of the SERDES macros is handled independently of the registers discussed in this section. The SERDES can be configured to shutdown unused links or fully shutdown. SERDES TX and RX channels may be enabled/disabled by writing to bit 0 of the SERDES\_CFGTXn\_CNTL and SERDES\_CFGRXn\_CNTL registers. The PLL and remaining SERDES functional blocks can be controlled by writing to the ENPLL signal in the SERDES\_CFG0\_CNTL register. This bit will drive the SERDES signal input, which will gate the reference clock to these blocks internally. This reference clock is sourced from a device pin specifically for the SERDES and is not derived from the CPU clock, thus it resets asynchronously. ENPLL will disable all SERDES high-speed output clocks. Since these clocks are distributed to all the links, ENPLL should only be used to completely shutdown the peripheral. It should be noted that shutdown of SERDES links in between normal packet transmissions is not permissible for two reasons. First, the serial RapidIO sends idle packets between data packets to maintain synchronization and lane alignment. Without this mechanism, the RapidIO RX logic can be mis-aligned for both 1X and 4X ports. Second, the lock time of the SERDES PLL would need to reoccur, which would slow down the operation.

When the SERDES ENTX signal is held low, the corresponding transmitter is powered down. In this state, both outputs, TXP and TXN, will be pulled high to VDDT.

# 2.3.10.1 Reset and Power Down Summary

After reset, the state of the peripheral depends on the default register values.

Software can also perform a hard reset of each logical block within the peripheral via the GBL\_EN and BLK*n*\_EN bits. The GBL\_EN bit resets the peripheral, while the rest of the device is not reset. The BLK*n*\_EN bits shut down unused portions of the peripheral, which minimizes power by resetting the appropriate logical block(s) and gating off the clock to the appropriate logical block(s). This should be considered an abrupt reset that is independent of the state of the peripheral and that resets the peripheral to its original state.

Upon reset of the peripheral, the device must reestablish communication with its link partner. Depending on the system, this may include a discovery phase in which a host processor reads the peripheral's CAR/CSR registers to determine its capabilities. In its simplest form, it involves retraining the SERDES and going through the initialization phase to synchronize on bit and word boundaries by using idle and control symbols, as described in Section 5.5.2 of the Part VI of the *RapidIO Interconnect Specification*. Until the peripheral and its partner are fully initialized and ready for normal operation, the peripheral will not send any data packets or non-status control symbols.

- GBL\_EN: Resets all MMRs, excluding Reset Ctl Values (0000h–01FCh). Resets all logical blocks except MMR configuration bus i/f. While asserted, the slave configuration bus is operational.
- BLK\_EN0: Resets all MMRs, excluding Reset Ctl Values (0000h–01FCh). Other logical blocks are unaffected, including MMR configuration bus i/f.
- BLK\_EN[n:1]: Single enable/reset per logical block. See Table 26.

# 2.3.10.2 Enable and Enable Status Registers

The enable and enable status registers are comprised of two global registers and nine pairs of block-specific registers. The global registers are summarized by Figure 32, Figure 33, Table 26, and Table 27. The GBL\_EN register is implemented with a single enable bit. This bit is logically ORed with the reset input to the module and is fanned out to all logical blocks within the peripheral.

#### Figure 32. GBL\_EN (Address 0030h)

| _311     | 0     |
|----------|-------|
| Reserved | EN    |
| R-0      | R/W-1 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

| 31               |                   |                  |                  |                  |                  |                  | 24               |
|------------------|-------------------|------------------|------------------|------------------|------------------|------------------|------------------|
|                  |                   |                  | Rese             | erved            |                  |                  |                  |
|                  |                   |                  | R                | -0               |                  |                  |                  |
| 23               |                   |                  |                  |                  |                  |                  | 16               |
|                  |                   |                  | Rese             | erved            |                  |                  |                  |
|                  |                   |                  | R                | -0               |                  |                  |                  |
| 15               |                   |                  |                  |                  | 10               | 9                | 8                |
|                  |                   | Rese             | erved            |                  |                  | BLK8_EN_<br>STAT | BLK7_EN_<br>STAT |
|                  |                   | R                | -0               |                  |                  | R-1              | R-1              |
| 7                | 6                 | 5                | 4                | 3                | 2                | 1                | 0                |
| BLK6_EN_<br>STAT | BLK5_EN_<br>STAT  | BLK4_EN_<br>STAT | BLK3_EN_<br>STAT | BLK2_EN_<br>STAT | BLK1_EN_<br>STAT | BLK0_EN_<br>STAT | GBL_EN_<br>STAT  |
| R-1              | R-1               | R-1              | R-1              | R-1              | R-1              | R-1              | R-1              |
|                  | and and units Mal |                  |                  |                  |                  |                  |                  |

Figure 33. GBL\_EN\_STAT (Address 0034h)

LEGEND: R = Read only; -n = Value after reset



SRIO Functional Description

| Register (Bit)     | Field        | Value | Description                                                                                                                                    |
|--------------------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| GBL_EN(31-1)       | Reserved     | 0     | These read-only bits return 0s when read.                                                                                                      |
| GBL_EN(0)          | EN           |       | Global enable. This bit controls reset to all clock domains within the peripheral.                                                             |
|                    |              | 0     | The peripheral is to be disabled (held in reset with clocks disabled).                                                                         |
|                    |              | 1     | The peripheral is to be enabled.                                                                                                               |
| GBL_EN_STAT(31-10) | Reserved     | 0     | These read-only bits return 0s when read.                                                                                                      |
| GBL_EN_STAT(9)     | BLK8_EN_STAT |       | Block 8 enable status. Logical block 8 is SRIO port 3.                                                                                         |
|                    |              | 0     | Logical block 8 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 8 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(8)     | BLK7_EN_STAT |       | Block 7 enable status. Logical block 7 is SRIO port 2.                                                                                         |
|                    |              | 0     | Logical block 7 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 7 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(7)     | BLK6_EN_STAT |       | Block 6 enable status. Logical block 6 is SRIO port 1.                                                                                         |
|                    |              | 0     | Logical block 6 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 6 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(6)     | BLK5_EN_STAT |       | Block 5 enable status. Logical block 5 is SRIO port 0.                                                                                         |
|                    |              | 0     | Logical block 5 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 5 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(5)     | BLK4_EN_STAT |       | Block 4 enable status. Logical block 4 is the message receive unit (RXU).                                                                      |
|                    |              | 0     | Logical block 4 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 4 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(4)     | BLK3_EN_STAT |       | Block 3 enable status. Logical block 3 is the message transmit unit (TXU)                                                                      |
|                    |              | 0     | Logical block 3 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 3 is enabled with clock running.                                                                                                 |
| GBL_EN_STAT(3)     | BLK2_EN_STAT |       | Block 2 enable status. Logical block 2 is the memory access unit (MAU).                                                                        |
|                    |              | 0     | Logical block 2 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 2 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(2)     | BLK1_EN_STAT |       | Block 1 enable status. Logical block 1 is the Load/Store module, which is comprised of the four Load/Store units (LSU1, LSU2, LSU3, and LSU4). |
|                    |              | 0     | Logical block 1 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 1 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(1)     | BLK0_EN_STAT |       | Block 0 enable status. Logical block 0 is the set of memory-mapped contr<br>registers for the SRIO peripheral.                                 |
|                    |              | 0     | Logical block 0 is in reset with its clock off.                                                                                                |
|                    |              | 1     | Logical block 0 is enabled with its clock running.                                                                                             |
| GBL_EN_STAT(0)     | GBL_EN_STAT  |       | Global enable status                                                                                                                           |
|                    |              | 0     | The peripheral is in reset with all its clocks off.                                                                                            |
|                    |              | 1     | The peripheral is enabled with all its clocks running.                                                                                         |

-..... ~7 ..... ..... ~ .... .

The 18 block-specific registers are represented by Figure 34 through Figure 39. These register pairs have bits with the same functions, which are described in Table 28.

### Figure 34. BLK0\_EN (Address 0038h)

| 31 1     | 0     |
|----------|-------|
| Reserved | EN    |
| R-0      | R/W-1 |

LEGEND: R = Read, W = Write, -n = Value after reset



# Figure 39. BLK8\_EN\_STAT (Address 007Ch)

| 31 1     | 0       |
|----------|---------|
| Reserved | EN_STAT |
| R-0      | R-1     |

LEGEND: R = Read, W = Write, -n = Value after reset

#### Table 28. Block Enable and Block Enable Status Field Descriptions

| Register(Bit)      | Field    | Valu<br>e | Description                                                     |
|--------------------|----------|-----------|-----------------------------------------------------------------|
| BLKn_EN(31-1)      | Reserved | 0         | These read-only bits return 0s when read.                       |
| BLKn_EN(0)         | EN       |           | Block <i>n</i> enable                                           |
|                    |          | 0         | Logical block <i>n</i> is to be reset with its clock off.       |
|                    |          | 1         | Logical block <i>n</i> is to be enabled with its clock running. |
| BLKn_EN_STAT(31-1) | Reserved | 0         | These read-only bits return 0s when read.                       |
| BLKn_EN_STAT(0)    | EN_STAT  |           | Block n enable status                                           |
|                    |          | 0         | Logical block <i>n</i> is reset with its clock off.             |
|                    |          | 1         | Logical block <i>n</i> is enabled with its clock running.       |

# 2.3.10.3 Software Shutdown Details

Power consumption is minimized for all logical blocks that are in shutdown. In addition to simply asserting the appropriate reset signal to each logical block within the peripheral, clocks are gated off to the corresponding logical block as well. Clocks are allowed to run for 32 clock cycles, which is necessary to fully reset each logical block. When the appropriate logical block is fully reset, the clock input to that subblock is gated off. When software asserts GBL\_EN/BLKn\_EN to release the logical block from reset, the clocks are un-gated and the GBL\_EN\_STAT/BLKn\_EN\_STAT bit(s) indicate a value of 1b.

**Note:** The BLK\_EN bits allow you to shut down and gate clocks to unused portions of the logic, while other parts of the peripheral continue to operate. When shutting down an individual block, if TXU and RXU queues are not torn down correctly, the DMA bus could hang. For example, setting BLK3\_EN = 0 (disabling the TXU) before a teardown of the queue could cause any outstanding DMA request returned to the peripheral for the TXU to hang the bus.

When using the GBL\_EN to shutdown/reset the entire peripheral, it is important to first stop all master-initiated commands on the DMA bus interface. For example, if the GBL\_EN is asserted in the middle of a DMA transfer from the peripheral, this could hang the bus. The procedure to follow is:

- Stop all RapidIO source transactions, including LSU and TXU operations. The four LSU blocks should indiciate a BSY status of 0b (offsets 0418h, 0438h, 0458h, 0478h). If an EDMA channel is used for driving the LSU, it must be stopped to prevent new/additional transfers. This procedure is outside the scope of this specification. Teardown of the TXU queues is accomplished by writing 0000FFFFh to RIO\_TX\_QUEUE\_TEAR\_DOWN (offset 0700h). Hardware will then tear down the queues and clear these bits automatically when the teardown is complete.
- 2. Stop all RapidIO message receive, RXU, operations. Teardown of the RXU queues is accomplished by writing 0000FFFFh to RIO\_RX\_QUEUE\_TEAR\_DOWN (offset 0740h). Hardware will then tear down the queues and clear these bits automatically when complete.
- 3. Once teardown is complete, clear the PEREN bit of the RIO\_PCR (offset 0004h) to stop all new logical layer transactions.
- 4. Wait 1 second to finish any current DMA transfer.
- 5. Deassert GBL\_EN (offset 0030h).

# 2.3.11 Emulation

Expected behavior during emulation halt is controlled within the peripheral by the SOFT and FREE bits of the peripheral control register (PCR). These bits are shown in Figure 40 and described in Table 29.

# Figure 40. Peripheral Control Register (PCR) - Address Offset 0004h

| 31 |          |   |       |       | 16    |
|----|----------|---|-------|-------|-------|
|    | Reserved |   |       |       |       |
|    | R-0      |   |       |       |       |
| 15 |          | 3 | 2     | 1     | 0     |
|    | Reserved |   | PEREN | SOFT  | FREE  |
|    | R-0      |   | R/W-0 | R/W-0 | R/W-1 |
|    |          |   |       |       |       |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

| Table 29. Peripheral Control Register (PCR) Field Descriptions |
|----------------------------------------------------------------|
|----------------------------------------------------------------|

| Bit  | Field    | Value | Description                                                                                                                                                                                                                                                                                                    |  |
|------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31–3 | Reserved | 0     | hese read-only bits return 0s when read.                                                                                                                                                                                                                                                                       |  |
| 2    | PEREN    |       | Peripheral enable. Controls the flow of data in the logical layer of the peripheral. As an initiator, it will prevent TX transaction generation; as a target, it will disable incoming requests. This should be the last enable bit to toggle when bringing the device out of reset to begin normal operation. |  |
|      |          | 0     | ata flow control is disabled.                                                                                                                                                                                                                                                                                  |  |
|      |          | 1     | Data flow control is enabled.                                                                                                                                                                                                                                                                                  |  |

| Bit | Field | Value | Description                                                                                                       |  |
|-----|-------|-------|-------------------------------------------------------------------------------------------------------------------|--|
| 1   | SOFT  |       | Soft stop. This bit and the FREE bit determine how the SRIO peripheral behaves during emulation nalts.            |  |
|     |       | 0     | Hard stop. All status registers are frozen in default state. (This mode is not supported on the SRIO peripheral.) |  |
|     |       | 1     | Soft stop                                                                                                         |  |
| 0   | FREE  |       | Free run                                                                                                          |  |
|     |       | 0     | he SOFT bit takes effect.                                                                                         |  |
|     |       | 1     | Free run. Peripheral ignores the emulation suspend signal and functions normally.                                 |  |

# Table 29. Peripheral Control Register (PCR) Field Descriptions (continued)

**Free Run Mode: (default mode)** Peripheral does not respond to an emulation suspend assertion. The peripheral functions normally, irrespective of the CPU emulation state.

**Soft Stop Mode:** The peripheral gracefully halts operations. The peripheral halts operation at a point that makes sense both to the internal DMA/data access operation and to the pin interface as described below, after finishing packet reception or transmission in progress:

- DMA bus DMA master: DMA bus requests in progress are allowed to complete (DMA bus has no means to throttle command in progress from the master). DMA bus requests that correspond to the same network packet are allowed to complete. No new DMA bus requests will be generated on the next new packet.
- Configuration bus MMR interface: All memory-mapped register (MMR) configuration bus requests are serviced as normal.
- Events/interrupts: New events/interrupts are not generated to the CPU for newly arriving packets. Current transactions are allowed to finish and may cause an interrupt upon completion.
- Slave pin interface: The pin interface functions as normal. If buffering is available in the peripheral, the peripheral services externally generated requests as long as possible. When the internal buffers are consumed, the peripheral will retry incoming network packets in the physical layer.
- **Master pin interface**: No new master requests are generated. Master requests in progress are allowed to complete, including all packets located in the physical layer transmit buffers.

Hard Stop Mode: The peripheral halts immediately. This mode is not supported in the peripheral.

# 2.3.12 TX Buffers, Credit, and Packet Reordering

Packets to be transmitted by the SRIO peripheral travel to logical layer buffers. The packets are then moved from the logical layer buffers to physical layer buffers. From the physical layer buffers, the packets are transmitted through a port to a connected device.

# 2.3.12.1 Multiple Ports With 1x Operation

With multiple ports in 1x mode, logical layer buffers are grouped per port and contain all priorities. Each group is 8 buffers deep. A counter is maintained for each port to track available buffer credit across the UDI. The count is initialized to 8 credits per port. The count is decremented each time a packet is sent across the UDI for a port. Each port buffer group has a buffer release signal which indicates the release of a packet from the logical layer buffer to the port's physical buffer, thus indicating the freeing up of space in the port's logical buffer.

Thresholds are used to govern outbound credit when requested by the protocol units (MAU, RXU, TXU, and the LSUs). These thresholds are programmable in the peripheral settings control register (PER\_SET\_CNTL at address offset 0020h).

The physical layer buffer tries to process all packets in the order they were sent across the UDI. However, it is also governed by a re-ordering algorithm to decide which packets may be sent to the physical layer buffer depending on credit availability there.



#### SRIO Functional Description

The physical layer buffers act like a FIFO unless there is a retry of a packet from the connected device, in which case a re-ordering algorithm is used. The algorithm searches backward through the buffer group for the first packet with the highest priority. If there are no higher priority packets in the queue, the current packet is sent again. As an example of the re-ordering algorithm, suppose a physical layer buffer group contains packets with the following priorities:

## 00123310

where the leftmost 0 represents the packet that was the first in, or the head of the queue. If this packet is retried, the next packet to be sent is the earliest packet with priority 3 (the lefthand 3). If that packet is sent successfully, the physical layer attempts to send the original retried packet again; otherwise, the physical layer repeats the re-ordering algorithm.

# 2.3.12.2 Single Port With 1x or 4x Operation

In the case when only one portis used, logical layer buffers are grouped per priority. Each priority is 8 buffers deep. A counter is maintained for each priority to track available buffer credit across the UDI. The count is initialized to 8 credits per port. The count is decremented each time a packet is sent across the UDI for a port. Each port buffer group has a buffer release signal which indicates the release of a packet from the logical layer buffer to the port's physical buffer, thus indicating the freeing up of space in the port's logical buffer.

A priority arbiter empties the logical layer buffer with the highest priority available first. For example, it empties all available priority 3 buffers before priority 2, 1, or 0.

The physical layer buffers act like a FIFO unless there is a retry of a packet from the connected device, in which case a re-ordering algorithm is used. The algorithm searches backward through the buffer group for the first packet with the highest priority. If there are no higher priority packets in the queue, the current packet is sent again. As an example of the re-ordering algorithm, suppose a physical layer buffer group contains packets with the following priorities:

00123310

where the leftmost 0 represents the packet that was the first in, or head of the queue. If this packet is retried, the next packet to be sent is the earliest packet with priority 3 (the lefthand 3). If that packet is sent successfully, the physical layer attempts to send the original retried packet again; otherwise, the physical layer repeats the re-ordering algorithm.

# 2.3.12.3 Unavailable Outbound Credit

At any time, if one of the credit counters reaches 0, no more buffer credit is available. The following describes how the protocol units deal with this case.

**MAU or RXU.**In the case of the MAU or the RXU, all outbound packets are response packets. As a result, the MAU or RXU is free to promote a packet's priority level until priority 3 is reached. If priority 3 cannot warrant a credit, the MAU or RXU keeps retrying on priority 3 until credit is available. The assumption is that if all priority levels become backed up, the physical layer re-ordering mechanism will be implemented to send out the highest priority packets first.

**LSUs.** For single-packet transfers, if the transfer is unsuccessful after 256 times of credit request, a completion code of 111b is indicated in the LSU status register (LSUn\_REG6). After reading this status, software must determine whether to try again, increase the priority, or try a different control flow.

For transfers (with up to 4K-byte payloads) requiring multiple packets, if the transfer is unsuccessful after 256 times of credit request for the first packet, a completion code of 111b is indicated in LSUn\_REG6. After the first packet is successfully completed, subsequent packets are given more retry attempts. The LSU makes up to 64K attempts to gain outbound credit for the subsequent packets. If the LSU is unsuccessful after the 64K attempts, a completion code of 111b is indicated in LSUn\_REG6.

**TXU.** The TXU cannot change state to handle inbound responses while it is requesting outbound credit. To avoid deadlock situations, the TXU tries for outbound credit in the following manner.

For single-segment messages, if the transfer is unsuccessful after 256 times of credit request, the TXU moves to the next queue in the round-robin loop of TX buffer descriptor queues. The TXU tries to send the unsent message again the next time the round-robin scheduler returns to the given queue.



For multi-segment messages, if the transfer is unsuccessful after 256 times of credit request for the first segment, the TXU moves to the next queue in the round-robin loop. The TXU tries to send the unsent message again the next time around the loop. After the first segment is granted outbound credit and is sent to the physical layer for transmission, all subsequent segments are given 64K attempts to gain outbound credit. If the TXU is unsuccessful after the 64K attempts, a completion code of 111b is written to the buffer descriptor, and the message is cancelled with no attempt to resend.

# 2.3.13 Initialization Example

# 2.3.13.1 Enabling the SRIO Peripheral

When the device is powered on, the SRIO peripheral is in a disabled state. Before any SRIO specific initialization can take place, the peripheral needs to be enabled; otherwise, its registers cannot be written, and the reads will all return a value of zero.

| /* Glb enable srio | */ |                     |   |            |
|--------------------|----|---------------------|---|------------|
| SRIO_REGS->GBL_EN  | =  | $0 \times 00000001$ | ; |            |
| SRIO_REGS->BLK0_EN | =  | 0x0000001           | ; | //MMR_EN   |
| SRIO_REGS->BLK5_EN | =  | 0x0000001           | ; | //PORT0_EN |
| SRIO_REGS->BLK1_EN | =  | $0 \times 00000001$ | ; | //LSU_EN   |
| SRIO_REGS->BLK2_EN | =  | 0x0000001           | ; | //MAU_EN   |
| SRIO_REGS->BLK3_EN | =  | 0x0000001           | ; | //TXU_EN   |
| SRIO_REGS->BLK4_EN | =  | $0 \times 00000001$ | ; | //RXU_EN   |
| SRIO_REGS->BLK6_EN | =  | 0x0000001           | ; | //PORT1_EN |
| SRIO_REGS->BLK7_EN | =  | 0x0000001           | ; | //PORT2_EN |
| SRIO_REGS->BLK8_EN | =  | 0x0000001           | ; | //PORT3_EN |

# 2.3.13.2 PLL, Ports, Device ID and Data Rate Initializations

To change from 1 lane to 4 lanes there are 2 registers that need to be programmed. See Table 30.

| Device        | SP_IP_MODE (offset 0x12004)<br>Bits 31-30 | PER_SET_CNTL (offset 0x0020)<br>Bit 8 | Port Mode |
|---------------|-------------------------------------------|---------------------------------------|-----------|
| TMS320TCI6482 | 0x00                                      | 0x00                                  | 1x/4p     |
| TMS320TCI6482 | 0x01                                      | 0x01                                  | 1x/1x     |

For example, Enable PLL, 333MHz, 1x/4p (srio4p1x\_mode = 1), x20, 125MHz ref. clock, 2.5 Gbps, half rate:

```
if (srio4p1x_mode){
      rdata = SRIO_REGS->PER_SET_CNTL;
      wdata = 0x0000014F; //4p1x
      mask = 0x000001FF;
      mdata = (wdata & mask) | (rdata & ~mask);
      SRIO_REGS->PER_SET_CNTL = mdata ; // enable PLL
}
else{
      wdata = 0x0000004F; // enable PLL, 1p4x
      rdata = SRIO_REGS->PER_SET_CNTL;
      mask = 0x000001FF;
      mdata = (wdata & mask) | (rdata & ~mask);
      SRIO_REGS->PER_SET_CNTL = mdata ; // enable PLL, 1p1x/4x
}
//INIT_MAC0
if (srio4p1x_mode){
         SRIO_REGS->SP_IP_MODE = 0x4400003F; // Jadis mltc/rst/pw enable, clear
}
else{
          SRIO_REGS->SP_IP_MODE = 0x0400003F; // Jadis mltc/rst/pw enable, clear
}
```

```
SRIO_REGS->SERDES_CFG0_CNTL = 0x00000013;
SRIO_REGS->SERDES_CFG1_CNTL = 0x00000000;
SRIO_REGS->SERDES_CFG2_CNTL = 0x00000000;
SRIO_REGS->SERDES_CFG3_CNTL = 0x00081121 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGRX1_CNTL = 0x00081121 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGRX2_CNTL = 0x00081121 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGRX2_CNTL = 0x00081121 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGRX3_CNTL = 0x00081121 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGRX3_CNTL = 0x00081121 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGRX3_CNTL = 0x00010811 ; // enable rx, half rate
SRIO_REGS->SERDES_CFGTX1_CNTL = 0x00010821 ; // enable tx, half rate
SRIO_REGS->SERDES_CFGTX2_CNTL = 0x00010821 ; // enable tx, half rate
SRIO_REGS->SERDES_CFGTX3_CNTL = 0x00010821 ; // enable tx, half rate
```

#### 2.3.13.3 Peripheral Initializations

#### Set Device ID Registers

```
rdata = SRIO_REGS->DEVICEID_REG1;
 wdata = 0x00ABBEEF;
 mask = 0x00FFFFFF;
 mdata = (wdata & mask) | (rdata & ~mask);
 SRIO_REGS->DEVICEID_REG1 = mdata ; // id-16b=BEEF, id-08b=AB
 rdata = SRIO_REGS->DEVICEID_REG2;
 wdata = 0 \times 000 ABBEEF;
  mask = 0x00FFFFFF;
  mdata = (wdata & mask) | (rdata & ~mask);
 SRIO_REGS->DEVICEID_REG2 = mdata ; // id-16b=BEEF, id-08b=AB
 rdata = SRIO REGS->PER SET CNTL;
 data = 0x0000000;
 mask = 0x0100000;
 mdata = (wdata & mask) | (rdata & ~mask);
 SRIO_REGS->PER_SET_CNTL = mdata; // bootcmpl=0
SRIO REGS->DEV ID
                            = 0xBEEF0030 ; // id=BEEF, ti=0x0030
                        = 0x00000000 ; // 0
= 0x00000030 ; // ti=0x0030
// ti=0x0000 nu
SRIO_REGS->DEV_INFO
SRIO_REGS->ASBLY_ID
SRIO_REGS->ASBLY_INFO
                          = 0 \times 00000000;
                                             // 0x0000, next ext=0x0100
                          = 0x20000019 ; // proc, bu ext, 16-bit ID, 34-bit addr
SRIO_REGS->PE_FEAT
SRIO_REGS->SRC_OP
                           = 0x0000FDF4; // all
SRIO_REGS->DEST_OP
                          = 0x0000FC04; // all except atomic
                          = 0x0000001; // 34-bit addr
SRIO_REGS->PE_LL_CTL
SRIO_REGS->LCL_CFG_HBAR
SRIO_REGS->LCL_CFG_BAR
                            = 0x00000000; // 0
                                           // 0
                            = 0x0000000;
SRIO_REGS->BASE_ID
                            = 0x00ABBEEF;
                                             // 16b-id=BEEF, 08b-id=AB
                                            // id=BEEF, lock
SRIO_REGS->HOST_BASE_ID_LOCK = 0x0000BEEF;
                                           // not touched
                           = 0 \times 00000000;
SRIO REGS->COMP TAG
SRIO_REGS->SP_IP_DISCOVERY_TIMER = 0x90000000;// 0, short cycles for sim
SRIO_REGS->IP_PRESCAL
                            = 0x00000021; // srv_clk prescalar=0x21 (333MHz)
SRIO_REGS->SP0_SILENCE_TIMER = 0x20000000;
SRIO_REGS->SP1_SILENCE_TIMER = 0x20000000;
SRIO_REGS->SP2_SILENCE_TIMER = 0x20000000;
SRIO_REGS->SP3_SILENCE_TIMER = 0x2000000;
   rdata = SRIO_REGS->PER_SET_CNTL;
   wdata = 0x0100000;
   mask = 0x0100000;
    mdata = (wdata & mask) | (rdata & ~mask);
   SRIO_REGS->PER_SET_CNTL = mdata; // bootcmpl=1
RIO_REGS->SP_LT_CTL
                            = 0xFFFFFF00; // long
```



```
SRIO_REGS->SP_RT_CTL= 0xFFFFFF00; // longSRIO_REGS->SP_GEN_CTL= 0x40000000; // agent, master, undiscoveredSRIO_REGS->SP0_CTL= 0x00600000; // enable i/oSRIO_REGS->SP1_CTL= 0x00600000; // enable i/oSRIO_REGS->SP2_CTL= 0x00600000; // enable i/oSRIO_REGS->SP3_CTL= 0x00600000; // enable i/o
SRIO_REGS->ERR_DET
                                      = 0x00000000 ; // clear
SRIO_REGS->ERR_EN
                                      = 0x00000000 ; // disable
SRIO_REGS->H_ADDR_CAPT
SRIO_REGS->ADDR_CAPT
                                       = 0x00000000 ; // clear
                                       = 0x00000000 ; // clear
SRIO_REGS->ID_CAPT
                                        = 0x00000000 ; // clear
SRIO_REGS->CTRL_CAPT
                                        = 0x00000000 ; // clear
SRIO_REGS->SP_IP_PW_IN_CAPT0 = 0x00000000 ; // clear
SRIO_REGS->SP_IP_PW_IN_CAPT1 = 0x00000000 ; // clear
SRIO_REGS->SP_IP_PW_IN_CAPT2 = 0x00000000 ; // clear
SRIO_REGS->SP_IP_PW_IN_CAPT3 = 0x00000000 ; // clear
```

//INIT\_WAIT wait for lane initialization

#### Read register to check portx(1-4) OK bit

```
// polling SRIO_MAC's port_ok bit
rdata = SRIO_REGS->P0_ERR_STAT ;
while ((rdata & 0x0000002) != 0x0000002)
{
         rdata = SRIO_REGS->P0_ERR_STAT ;
if (srio4p1x_mode){
         rdata = SRIO_REGS->P1_ERR_STAT;
         while ((rdata & 0x0000002) != 0x0000002)
         {
               rdata = SRIO_REGS->P1_ERR_STAT;
         }
         rdata = SRIO REGS->P2 ERR STAT;
         while ((rdata & 0x0000002) != 0x0000002)
         {
               rdata = SRIO REGS->P2 ERR STAT;
         }
         rdata = SRIO_REGS->P3_ERR_STAT;
         while ((rdata & 0x0000002) != 0x0000002)
         {
               rdata = SRIO_REGS->P3_ERR_STAT;
         }
}
```

## Assert the PEREN bit to enable logical layer data flow

SRIO\_REGS->PCR = 0x00000004; // peren

# 2.3.14 Bootload Capability

## 2.3.14.1 Configuration and Operation

Figure 41 illustrates the system components involved in bootload operation. It is assumed that an external device will initiate the bootload data transfer and master the DMA interface. Upon reset, the following sequence of events must occur:

- 1. DSP is placed in SRIO boot mode by HW mode pins.
- 2. Host takes DSP out of reset (POR or RST). The peripheral's state machines and registers are reset.
- 3. Internal boot-strap ROM configures device registers, including SERDES, and DMA. DSP executes internal ROM code to initialize SRIO.
  - Choice of 4 pin selectable configurations
  - Optionally, I2C boot can be used to configure SRIO



- 4. DSP executes idle instruction.
- 5. RapidIO ports send Idle control symbols to train PHYs.
- 6. Host enabled to explore system with RapidIO Maintenance packets.
- 7. Host identifies, enumerates and initializes the RapidIO device.
- 8. Host controller configures DSP peripherals through maintenance packets.
  - SRIO Device IDs are set for DSPs (either by pin strapping or by host manipulation)
- 9. Boot Code sent from host controller to DSP L2 memory base address via NWRITE.
- 10. DSP CPU is awakened by an interrupt such as a RapidIO DOORBELL packet.
- 11. Boot Code is executed and normal operation follows.





## 2.3.14.2 Bootload Data Movement

The system host is responsible for writing the bootload data into the DSP's L2 memory. As such, bootload is only supported using the direct I/O model, and not the message passing model. Bootload data must be sent in packets with explicit L2 memory addresses indicating proper destination within the DSP. As part of the peripheral's configuration, it should be set up to transfer the desired bootload program to the DSP's memory through normal DMA bus commands.

#### 2.3.14.3 Device Wakeup

Upon completion of the bootload data transfer, the system host issues a DOORBELL interrupt to the DSP. The RapidIO peripheral processes this interrupt in a manner similar to that described in Section 4, monitoring the DMA bus write-with-response commands to ensure that the data has been completely transferred through the DMA. This interrupt wakes up the CPUs by pulling them out of their reset state.

The 16-bit data field of the DOORBELL packet should be configured to interrupt Core 0 by setting a corresponding ICSR bit as described in Figure 46.

# 2.3.15 RX Multicast Support, Daisy Chain Operation and Packet Forwarding

# 2.3.15.1 RX Multicast Support

Multicast transactions are I/O packets that specify a destination address within the header. This address is used directly for the internal DSP transfers and is not modified in any way. For this reason, multi-cast support is limited to groups containing devices with the same memory map, or other devices that can perform address translation. It is the responsibility of the system designer to pre-determine valid multi-cast address ranges.

When a packet is received, the packet's tt field and DestID are checked against the main DeviceID (offset 0x0080) and the MulticastID (see Table 31). If there is no match, the packet is destroyed and not forwarded to the logical layer. If there is a match, it is forwarded to the logical layer. Since multicast operations are defined to be operations that do not require responses, they are limited to NWRITE and SWRITE operations and forwarded to the MAU.

As an endpoint device, the peripheral accepts packets based on the destination ID. Two options exist for packet acceptance and are mode selectable. The first option is to only accept packets whose DestIDs match the local deviceID in 0x0080. This provides a level of security. The second option is is system multicast operation.

| Table 31. Multicast DeviceID Operation |                                   |                                       |                                                           |
|----------------------------------------|-----------------------------------|---------------------------------------|-----------------------------------------------------------|
| Device                                 | Local DeviceID<br>Register Offset | Multicast DeviceID<br>Register Offset | Endpoint Device Requirements                              |
| TMS320TCI6482                          | 0080h                             | 0084h                                 | Accepts discrete multiple DestIDs from<br>incoming packet |

# 2.3.15.2 Daisy Chain Operation and Packet Forwarding

Some applications may require daisy chaining of devices together versus using a switch fabric. Typically, these applications are low cost implementations. Daisy chains have variable system latency depending on device position within the chain. Daisy chain implementations also have reduced bandwidth capabilities, since the link bandwidth doesn't change, the bandwidth allocated to each device in the chain is limited (sum of devices' individual bandwidth needs can't exceed link bandwidth).

To support daisy chain or ring topologies, the peripheral features a hardware packet forwarding function. This feature eliminates the need for software to be involved in routing a packet to the next device in the chain. The basic idea behind the hardware packet forwarding logic is to provide an input port to output port path such that the packets never leave the peripheral (no DMA transfer). A simple check of an in-coming packet's DestID versus the device's DeviceID and MulticastID is done to determine if the packet should be forwarded. If the packet's DestID matches DeviceID, the packet is accepted and processed by the device and forwarded based on the rules outlined in Section 2.3.15.1. If the packet's DestID doesn't match either, the packet is simply destroyed or forwarded, depending on the whether the hardware packet forwarding is enabled.

Additionally, it is beneficial to be able to only forward a packet if the destination ID is one of the devices in the chain/ring. Otherwise, a rogue packet may be forwarded endlessly using up valuable bandwidth. The hardware packet forwarding uses a 4 entry mapping table shown in Table 32 and Table 33. These mapping entries allow programmable selection of output port based on the in-coming packets DestID range. Since the packet forwarding is done at the logical layer and not the physical layer, CRCs will be regenerated for each forwarded packet.

# 2.3.15.3 Enabling Multicast and Packet Forwarding

In order to enable multicast support, bit 5 of the SP\_IP\_MODE (offset 0x12004) must be set to 1.The multicast mode is disabled by simply writing the same deviceID into the registers listed in Table 31. Hardware packet forwarding can be disabled by assigning all the table entry Upper and Lower deviceID boundaries equal to the local DeviceID value.

# Figure 42. Packet Forwarding Register *n* for 16-Bit Device IDs (PF\_16B\_CNTL*n*) Offsets 0x0090, 0x0098, 0x00A0, 0x00A8

| 31                | 16 15 |                       |  |
|-------------------|-------|-----------------------|--|
| 16BIT_DEVID_UP_BO | UND   | 16BIT_DEVID_LOW_BOUND |  |
| R/W-FFFh          |       | R/W-FFFFh             |  |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 32. Packet Forwarding Register *n* for 16-Bit DeviceIDs (PF\_16B\_CNTL*n*) Field Descriptions

| Bit   | Field                 | Value       | Description                                                                               |
|-------|-----------------------|-------------|-------------------------------------------------------------------------------------------|
| 31–16 | 16BIT_DEVID_UP_BOUND  | 0000h-FFFFh | Upper 16-bit DeviceID boundary. DestID above this range cannot use the table entry.       |
| 15–0  | 16BIT_DEVID_LOW_BOUND | 0000h-FFFFh | Lower 16-bit DeviceID boundary. DestID lower than this number cannot use the table entry. |



# Figure 43. Packet Forwarding Register *n* for 8-Bit Device IDs (PF\_8B\_CNTL*n*) Offsets 0x0094, 0x009C, 0x00A4, 0x00AC

| 31 |                      | 18 17 16           |
|----|----------------------|--------------------|
|    | Reserved             | OUT_BOUND_<br>PORT |
|    | R-0                  | R/W-3              |
| 15 |                      | 8                  |
|    | 8BIT_DEVID_UP_BOUND  |                    |
|    | R/W-FFh              |                    |
| 7  |                      | 0                  |
|    | 8BIT_DEVID_LOW_BOUND |                    |
|    |                      |                    |

R/W-FFh

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

# Table 33. Packet Forwarding Register *n* for 8-Bit DeviceIDs (PF\_8B\_CNTL*n*) Field Descriptions

| Bit   | Field                | Value   | Description                                                                                              |
|-------|----------------------|---------|----------------------------------------------------------------------------------------------------------|
| 31–18 | Reserved             | 0       | Reserved                                                                                                 |
| 17–16 | OUT_BOUND_PORT       | 0–3     | Output port number for packets whose DestID falls within the 8-bit or 16-bit range for this table entry. |
| 15–8  | 8BIT_DEVID_UP_BOUND  | 00h–FFh | Upper 8-bit DeviceID boundary. DestID above this range cannot use the table entry.                       |
| 7–0   | 8BIT_DEVID_LOW_BOUND | 00h–FFh | Lower 8-bit DeviceID boundary. DestID lower than this number cannot use the table entry.                 |

# 3 Logical/Transport Error Handling and Logging

Error management registers allow detection and logging of logical/transport layer errors. The detectable errors are captured in the logical layer error detect CSR (see Figure 44). Table 34 names the functional block(s) involved for each detectable error condition, and includes brief descriptions of the errors captured.

# Figure 44. Logical/Transport Layer Error Detect CSR (ERR\_DET)

| 31                    | 30                   | 29   | 9        | 28                 | 27                   | 26       | 25                  | 24                    |  |  |  |  |
|-----------------------|----------------------|------|----------|--------------------|----------------------|----------|---------------------|-----------------------|--|--|--|--|
| IO_ERR_<br>RSPNS      | MSG_ERR_<br>RSPNS    | Rese |          | ERR_MSG_<br>FORMAT | ILL_TRANS_<br>DECODE | Reserved | MSG_REQ_<br>TIMEOUT | PKT_RSPNS_<br>TIMEOUT |  |  |  |  |
| R/W-0                 | R/W-0                | R-   | 0        | R/W-0              | R/W-0                | R-0      | R/W-0               | R/W-0                 |  |  |  |  |
| 23                    | 22                   |      | 21       |                    |                      |          |                     |                       |  |  |  |  |
| UNSOLICITED_<br>RSPNS | UNSUPPOI             | _    | Reserved |                    |                      |          |                     |                       |  |  |  |  |
| R/W-0                 | R/W-0                | C    |          | R-0                |                      |          |                     |                       |  |  |  |  |
|                       |                      |      |          |                    |                      |          |                     | 8                     |  |  |  |  |
|                       |                      |      |          | Rese               | erved                |          |                     |                       |  |  |  |  |
|                       |                      |      |          | R                  | -0                   |          |                     |                       |  |  |  |  |
| 7                     | 6                    | 5    |          |                    |                      |          |                     | 0                     |  |  |  |  |
| RX_CPPI_<br>SECURITY  | RX_IO_DMA_<br>ACCESS |      |          |                    | Rese                 | erved    |                     |                       |  |  |  |  |
| R/W-0                 | R/W-0                |      | R-0      |                    |                      |          |                     |                       |  |  |  |  |
|                       |                      |      |          |                    |                      |          |                     |                       |  |  |  |  |

LEGEND: R = Read; W = Write; -n = Value after reset

## Table 34. Logical/Transport Layer Error Detect CSR (ERR\_DET) Field Descriptions

| Bit | Field            | Value | Description                                                                                                                 |
|-----|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------|
| 31  | IO_ERR_RSPNS     |       | IO error response (endpoint device only)                                                                                    |
|     |                  | 0     | An LSU did not receive an ERROR response to an IO logical layer request.                                                    |
|     |                  | 1     | An LSU received an ERROR response to an IO logical layer request. To clear this bit, write 0 to it.                         |
| 30  | MSG_ERR_RSPNS    |       | Message error response (endpoint device only)                                                                               |
|     |                  | 0     | The TXU did not receive an ERROR response to a message logical layer request.                                               |
|     |                  | 1     | The TXU received an ERROR response to a message logical layer request. To clear this bit, write 0 to it.                    |
| 29  | Reserved         | 0     | This read-only bit returns 0 when read.                                                                                     |
| 28  | ERR_MSG_FORMAT   |       | Error in message format (endpoint device only)                                                                              |
|     |                  | 0     | The RXU did not receive a message data payload with an invalid size or segment.                                             |
|     |                  | 1     | The RXU received a message data payload with an invalid size or segment. To clear this bit, write 0 to it.                  |
| 27  | ILL_TRANS_DECODE |       | Illegal transaction decode (switch or endpoint device)                                                                      |
|     |                  |       | For an LSU or the TXU:                                                                                                      |
|     |                  | 0     | The LSU/TXU did not receive illegal fields in the response packet for an IO/message transaction.                            |
|     |                  | 1     | The LSU/TXU received illegal fields in the response packet for an IO/message transaction. To clear this bit, write 0 to it. |
|     |                  |       | For the MAU or the RXU:                                                                                                     |
|     |                  | 0     | The MAU/RXU did not receive illegal fields in the request packet for an IO/message transaction.                             |
|     |                  | 1     | The MAU/RXU received illegal fields in the request packet for an IO/message transaction. To clear this bit, write 0 to it.  |
| 26  | Reserved         | 0     | This read-only bit returns 0 when read.                                                                                     |



# Table 34. Logical/Transport Layer Error Detect CSR (ERR\_DET) Field Descriptions (continued)

| Bit  | Field             | Value | Description                                                                                                                                                                         |
|------|-------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25   | MSG_REQ_TIMEOUT   |       | Message request timeout (endpoint device only)                                                                                                                                      |
|      |                   | 0     | A timeout has not been detected by RXU.                                                                                                                                             |
|      |                   | 1     | A timeout has been detected by the RXU. A required message request has not been received by the RXU within the specified time-out interval. To clear this bit, write 0 to it.       |
| 24   | PKT_RSPNS_TIMEOUT |       | Packet response timeout (endpoint device only)                                                                                                                                      |
|      |                   | 0     | A timeout has not been detected by an LSU or the TXU.                                                                                                                               |
|      |                   | 1     | A timeout has been detected by an LSU or the TXU. A required response has not been received by the LSU/TXU within the specified timeout interval. To clear this bit, write 0 to it. |
| 23   | UNSOLICITED_RSPNS |       | Unsolicited response (switch or endpoint device)                                                                                                                                    |
|      |                   | 0     | An unsolicited response packet has not been received by an LSU or the TXU.                                                                                                          |
|      |                   | 1     | An unsolicited response packet has been received by an LSU or the TXU. To clear this bit, write 0 to it.                                                                            |
| 22   | UNSUPPORTED_TRANS |       | Unsupported transaction (switch or endpoint device)                                                                                                                                 |
|      |                   | 0     | The MAU has not received an unsupported transaction.                                                                                                                                |
|      |                   | 1     | The MAU has received an unsupported transaction. That is, the MAU received a transaction that is not supported in the destination operations CAR. To clear this bit, write 0 to it. |
| 21–8 | Reserved          | 0     | These read-only bits return 0 when read.                                                                                                                                            |
| 7    | RX_CPPI_SECURITY  |       | RX CPPI security error                                                                                                                                                              |
|      |                   | 0     | The RXU has not detected an access block.                                                                                                                                           |
|      |                   | 1     | The RXU has detected an access block. That is, access to one of the RX queues was blocked. To clear this bit, write 0 to it.                                                        |
| 6    | RX_IO_DMA_ACCESS  |       | RX IO DMA access error                                                                                                                                                              |
|      |                   | 0     | A DMA access to the MAU has not been blocked.                                                                                                                                       |
|      |                   | 1     | A DMA access to the MAU was blocked. To clear this bit, write 0 to it.                                                                                                              |
| 5–0  | Reserved          | 0     | These read-only bits return 0 when read.                                                                                                                                            |





# 4 Interrupt Conditions

This section defines the CPU interrupt capabilities and requirements of the peripheral.

# 4.1 CPU Interrupts

The following interrupts are supported by the RIO peripheral.

- Error status: Event indicating that a run-time error was reached. The CPU should reset/resynchronize the peripheral.
- Critical error: Event indicating that a critical error state was reached. The CPU should reset the system.
- CPU servicing: Event indicating that the CPU should service the peripheral.

# 4.2 General Description

The RIO peripheral is capable of generating various types of CPU interrupts. The interrupts serve two general purposes: error indication and servicing requests.

Since RapidIO is a packet oriented interface, the peripheral must recognize and respond to inbound signals from the serial interface. There are no GPIO or external pins used to indicate an interrupt request. Thus, the interrupt requests are signaled either by an external RapidIO device through the packet protocols discussed as follows, or are generated internally by the RIO peripheral.

CPU servicing interrupts lag behind the corresponding data, which was generally transferred from an external processing element into local L2 memory. This transfer can use a messaging or direct I/O protocol. When the single or multi-packet data transfer is complete, the external PE, or the peripheral itself, must notify the local processor that the data is available for processing. To avoid erroneous data being processed by the local CPU, the data transfer must complete through the DMA before the CPU interrupt is serviced. This condition could occur since the data and interrupt queues are independent of each other, and DMA transfers can stall. To avoid this condition, all data transfers from the peripheral through the DMA use write-with-response DMA bus commands, allowing the peripheral to always be aware that outstanding transfers have completed. Interrupts are generated only after all DMA bus responses are received. Since all RapidIO packets are handled sequentially, and submitted on the same DMA priority queue, the peripheral must keep track of the number of DMA requests submitted and the number of responses received. Thus, a simple counter within the peripheral ensures that data packets have arrived in memory before submitting an interrupt.

The sending device initiates the interrupt by using the RapidIO defined DOORBELL message. The DOORBELL packet format is shown in Figure 45. The DOORBELL functionality is user-defined. This packet type is commonly used to initiate CPU interrupts. A DOORBELL packet is not associated with a particular data packet that was previously transferred, so the INFO field of the packet must be configured to reflect the DOORBELL bit to be serviced for the correct TID info to be processed.







#### Interrupt Conditions

The DOORBELL packet's 16-bit INFO field indicates which DOORBELL register interrupt bit to set. There are four DOORBELL registers, each currently with 16 bits, allowing 64 interrupt sources or circular buffers (see Table 23 for assignment of the 16 bits of DOORBELL\_INFO field). Each bit can be assigned to any core as described by the Interrupt Condition Routing Registers. Additionally, each status bit is user-defined for the application. For instance, it may be desirable to support multiple priorities with multiple TID circular buffers per core if control data uses a high priority (for example, priority = 2), while data packets are sent on priority 0 or 1. This allows the control packets to have preference in the switch fabric and arrive as quickly as possible. Since it may be required to interrupt the CPU for both data and control packet processing separately, separate circular buffers are used, and DOORBELL packets must distinguish between them for interrupt servicing. If any reserved bit in the DOORBELL info field is set, an error response is sent.

The interrupt approach to the messaging protocol is somewhat different. Since the source device is unaware of the data's physical location in the destination device, and since each messaging packet contains size and segment information, the peripheral can automatically generate the interrupt after it has successfully received all packet segments comprising the complete message. This DMA interface uses the Communications Port Programming Interface (CPPI). This interface is a link-listed approach versus a circular buffer approach. Data buffer descriptors which contain information such as start of Packet (SOP), end of packet (EOP), end of queue (EOQ), and packet length are built from the RapidIO header fields. The data buffer descriptors also contain the address of the corresponding data buffer as assigned by the receive device. The data buffer descriptors are then link-listed together as multiple packets are received. Interrupts are generated by the peripheral after all segments of the messages are received and successfully transferred through the DMA bus with the write-with-response commands. Interrupt pacing is also implemented at the peripheral level to manage the interrupt rate, as described in Section 4.7.

Error handling on the RapidIO link is handled by the peripheral, and as such, does not require the intervention of software for recovery. This includes CRC errors due to bit rate errors that may cause erroneous or invalid operations. The exception to this statement is the use of the RapidIO error management extended features. This specification monitors and tabulates the errors that occur on a per port basis. If the number of errors exceeds a pre-determined configurable amount, the peripheral should interrupt the CPU software and notify that an error condition exits. Alternatively, if a system host is used, the peripheral may issue a port-write operation to notify the system software of a bad link.

A system reset, or Critical Error interrupt, can be initialized through the RapidIO link. This procedure allows an external device to reset the local device, causing all state machine and configuration registers to reset to their original values. This is executed with the Reset-Device command described in Part VI, Section 3.4.5 of the RapidIO *Physical Layer 1x/4x LP-Serial Specification*. Four sequential Reset-Device control symbols are needed to avoid inadvertent resetting of a device.

# 4.3 Interrupt Condition Status and Clear Registers

Interrupt condition status and clear registers configure which CPU interrupts are to be generated and how, based on the peripheral activity. All peripheral conditions that result in a CPU interrupt are grouped so that the interrupt can be accessed in the minimum number of register reads possible.

For each of the three types of interrupts (CPU servicing, error status, and critical error), there are two sets of registers:

- Interrupt Condition Status Register (ICSR): Status register that reflects the state of each condition that can trigger the interrupt. The general description of each interrupt condition status bit (ICSx) is given in Table 35.
- Interrupt Condition Clear Register (ICCR): Command register that allows each condition to be cleared. This is typically required prior to enabling a condition, so that spurious interrupts are not generated. Table 35 shows the general description of an interrupt condition clear bit (ICCx).

These registers are accessible in the memory map of the CPU. The CPU controls the clear register. The status register is readable by the CPU to determine the peripheral condition.

|       |        |             | -     |                                       |
|-------|--------|-------------|-------|---------------------------------------|
| Field | Access | Reset Value | Value | Function                              |
| ICSx  | R      | 0           | 0     | Condition not present                 |
|       |        |             | 1     | Condition present                     |
| ICCx  | W      | 0           | 0     | No effect                             |
|       |        |             | 1     | Clear the condition status bit (ICSx) |

# Table 35. Interrupt Condition Status and Clear Bits

# 4.3.1 Doorbell Interrupt Condition Status and Clear Registers

The interrupt condition status registers (ICSRs) and the interrupt condition clear registers (ICCRs) for the four doorbells are shown in Figure 46 through Figure 49. These registers are used when the SRIO peripheral receives doorbell packets. The 16 ICS bits of each interrupt condition status register (ICSR) indicate the incoming doorbell information packet. For example, the bits ICS15, ICS8, and ICS0 of DOORBELL0\_ICSR correspond to Doorbell 0 information bits 15, 8, and 0. The 16 ICC bits of each interrupt condition clear register (ICCR) are used to clear the corresponding bits in the ICSR. For example, the ICC7 bit of DOORBELL2\_ICCR is used to clear the ICS7 bit of DOORBELL2\_ICSR.

# Figure 46. Doorbell 0 Interrupt Condition Status and Clear Registers

Doorbell 0 Interrupt Condition Status Register (DOORBELL0\_ICSR) (Address Offset 0200h)

| 31     |            |          |          |          |           |       |         |          |          |          |      |      |      |      | 16   |
|--------|------------|----------|----------|----------|-----------|-------|---------|----------|----------|----------|------|------|------|------|------|
|        |            |          |          |          |           |       | Rese    | erved    |          |          |      |      |      |      |      |
| R-0    |            |          |          |          |           |       |         |          |          |          |      |      |      |      |      |
| 15     | 14         | 13       | 12       | 11       | 10        | 9     | 8       | 7        | 6        | 5        | 4    | 3    | 2    | 1    | 0    |
| ICS15  | ICS14      | ICS13    | ICS12    | ICS11    | ICS10     | ICS9  | ICS8    | ICS7     | ICS6     | ICS5     | ICS4 | ICS3 | ICS2 | ICS1 | ICS0 |
| R-0    | R-0        | R-0      | R-0      | R-0      | R-0       | R-0   | R-0     | R-0      | R-0      | R-0      | R-0  | R-0  | R-0  | R-0  | R-0  |
| Doorbe | ll 0 Inter | rupt Con | dition C | lear Reg | ister (DC | ORBEL | L0_ICCR | ) (Addre | ss Offse | t 0208h) |      |      |      |      |      |
| 31     |            |          |          |          |           |       |         |          |          |          |      |      |      |      | 16   |
|        |            |          |          |          |           |       | Rese    | erved    |          |          |      |      |      |      |      |
|        |            |          |          |          |           |       | R       | -0       |          |          |      |      |      |      |      |
| 15     | 14         | 13       | 12       | 11       | 10        | 9     | 8       | 7        | 6        | 5        | 4    | 3    | 2    | 1    | 0    |
| ICC15  | ICC14      | ICC13    | ICC12    | ICC11    | ICC10     | ICC9  | ICC8    | ICC7     | ICC6     | ICC5     | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |

LEGEND: R = Read only; W = Write only; -n = Value after reset

W-0

W-0

# Figure 47. Doorbell 1 Interrupt Condition Status and Clear Registers

W-0

W-0

W-0

W-0

W-0

W-0

W-0

W-0

. .

| Doorbell 1 Interrupt Condition Status Register (DOORBELL1_ICSR) (Address Offset | : 0210h) |
|---------------------------------------------------------------------------------|----------|
| 24                                                                              |          |

W-0

W-0

W-0

| 31    |          |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|-------|----------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       | Reserved |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
|       | R-0      |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
| 15    | 14       | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICS15 | ICS14    | ICS13 | ICS12 | ICS11 | ICS10 | ICS9 | ICS8 | ICS7 | ICS6 | ICS5 | ICS4 | ICS3 | ICS2 | ICS1 | ICS0 |
| R-0   | R-0      | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  |

# Doorbell 1 Interrupt Condition Clear Register (DOORBELL1\_ICCR) (Address Offset 0218h)

| 31                                                            |          |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|---------------------------------------------------------------|----------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|                                                               | Reserved |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
|                                                               | R-0      |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
| 15                                                            | 14       | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15                                                         | ICC14    | ICC13 | ICC12 | ICC11 | ICC10 | ICC9 | ICC8 | ICC7 | ICC6 | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |
| W-0                                                           | W-0      | W-0   | W-0   | W-0   | W-0   | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  |
| LEGEND: R = Read only; W = Write only; -n = Value after reset |          |       |       |       |       |      |      |      |      |      |      |      |      |      |      |

W-0

W-0

W-0

# Figure 48. Doorbell 2 Interrupt Condition Status and Clear Registers

## Doorbell 2 Interrupt Condition Status Register (DOORBELL2\_ICSR) (Address Offset 0220h)

| 31    |       |       |       |       |       |      |      |       |      |      |      |      |      |      | 16   |
|-------|-------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------|
|       |       |       |       |       |       |      | Rese | erved |      |      |      |      |      |      |      |
|       | R-0   |       |       |       |       |      |      |       |      |      |      |      |      |      |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICS15 | ICS14 | ICS13 | ICS12 | ICS11 | ICS10 | ICS9 | ICS8 | ICS7  | ICS6 | ICS5 | ICS4 | ICS3 | ICS2 | ICS1 | ICS0 |
| R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  | R-0   | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  |

#### Doorbell 2 Interrupt Condition Clear Register (DOORBELL2\_ICCR) (Address Offset 0228h)

Doorbell 3 Interrupt Condition Status Register (DOORBELL3\_ICSR) (Address Offset 0230h)

| 31    |                                                               |       |       |       |       |      |      |      |      |      |      |      |      |      | 16   |
|-------|---------------------------------------------------------------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
|       | Reserved                                                      |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
|       | R-0                                                           |       |       |       |       |      |      |      |      |      |      |      |      |      |      |
| 15    | 14                                                            | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15 | ICC14                                                         | ICC13 | ICC12 | ICC11 | ICC10 | ICC9 | ICC8 | ICC7 | ICC6 | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |
| W-0   | W-0                                                           | W-0   | W-0   | W-0   | W-0   | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  |
| LEGEN | LEGEND: R = Read only; W = Write only; -n = Value after reset |       |       |       |       |      |      |      |      |      |      |      |      |      |      |

# Figure 49. Doorbell 3 Interrupt Condition Status and Clear Registers

| 31       |             |             |             |             |             |           |        |         |           |           |           |           |           |                  | 16   |
|----------|-------------|-------------|-------------|-------------|-------------|-----------|--------|---------|-----------|-----------|-----------|-----------|-----------|------------------|------|
|          |             |             |             |             |             |           | Rese   | erved   |           |           |           |           |           |                  |      |
|          |             |             |             |             |             |           | R      | -0      |           |           |           |           |           |                  |      |
| 15       | 14          | 13          | 12          | 11          | 10          | 9         | 8      | 7       | 6         | 5         | 4         | 3         | 2         | 1                | 0    |
| ICS15    | ICS14       | ICS13       | ICS12       | ICS11       | ICS10       | ICS9      | ICS8   | ICS7    | ICS6      | ICS5      | ICS4      | ICS3      | ICS2      | ICS1             | ICS0 |
| R-0      | R-0         | R-0         | R-0         | R-0         | R-0         | R-0       | R-0    | R-0     | R-0       | R-0       | R-0       | R-0       | R-0       | R-0              | R-0  |
|          |             |             |             |             |             |           |        |         |           |           |           |           |           |                  |      |
| 31       |             |             |             |             |             |           | Rese   | erved   |           |           |           |           |           |                  | 16   |
| 31       |             |             |             |             |             |           | Rese   |         |           | -         |           |           |           |                  | 16   |
| 31<br>15 | 14          | 13          | 12          | 11          | 10          | 9         |        |         | 6         | 5         | 4         | 3         | 2         | 1                | 0    |
|          | 14<br>ICC14 | 13<br>ICC13 | 12<br>ICC12 | 11<br>ICC11 | 10<br>ICC10 | 9<br>ICC9 | R      | -0      | 6<br>ICC6 | 5<br>ICC5 | 4<br>ICC4 | 3<br>ICC3 | 2<br>ICC2 | 1<br>ICC1        |      |
| 15       |             | -           |             |             | -           |           | R<br>8 | -0<br>7 | -         | -         | -         | -         | 1         | 1<br>ICC1<br>W-0 | 0    |

# 4.3.2 CPPI Interrupt Condition Status and Clear Registers

The ICSRs and the ICCRs for the RXU and the TXU are shown in Figure 50 and Figure 51. These interrupt condition registers are used when the SRIO peripheral receives and transmits data message packets. Each ICS bit corresponds to the interrupt for one of the buffer descriptor queues. For example, the bits ICS15, ICS8, and ICS0 of RX\_CPPI\_ICSR correspond to RX buffer descriptor queues 15, 8, and 0. Similarly, the bits ICS15, ICS8, and ICS0 of TX\_CPPI\_ICSR support TX buffer descriptor queues 15, 8, and 0. The 16 ICC bits of each interrupt condition clear register (ICCR) are used to clear the corresponding bits in the ICSR.

For reception, the clearing of any ICSR bit depends on the CPU writing the value of the last buffer descriptor processed to the completion pointer (CP) register for the queue (QUEUE*n*\_RXDMA\_CP). Port hardware clears the ICSR bit only if the CP value written by the CPU equals the port written value in the CP register.

For transmission, the clearing of any ICSR bit is dependent on the CPU writing to the CP register for the queue (QUEUEn\_TXDMA\_CP). The CPU acknowledges the interrupt after reclaiming all available buffer descriptors by writing the CP value. This value is compared against the port written value in the CP register. If the values are equal, the interrupt is deasserted.

# Figure 50. RX CPPI Interrupt Condition Status and Clear Registers

RX CPPI Interrupt Condition Status Register (RX\_CPPI\_ICSR) (Address Offset 0240h)

| 31    |       |       |       |       |       |      |      |       |      |      |      |      |      |      | 16   |
|-------|-------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------|
|       |       |       |       |       |       |      | Rese | erved |      |      |      |      |      |      |      |
|       |       |       |       |       |       |      | R    | -0    |      |      |      |      |      |      |      |
| 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICS15 | ICS14 | ICS13 | ICS12 | ICS11 | ICS10 | ICS9 | ICS8 | ICS7  | ICS6 | ICS5 | ICS4 | ICS3 | ICS2 | ICS1 | ICS0 |
| R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0  | R-0  | R-0   | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  |

## RX CPPI Interrupt Condition Clear Register (RX\_CPPI\_ICCR) (Address Offset 0248h)

| 31    |          |          |          |          |       |          |      |       |      |      |      |      |      |      | 16   |
|-------|----------|----------|----------|----------|-------|----------|------|-------|------|------|------|------|------|------|------|
|       |          |          |          |          |       |          | Rese | erved |      |      |      |      |      |      |      |
|       |          |          |          |          |       |          | R    | -0    |      |      |      |      |      |      |      |
| 15    | 14       | 13       | 12       | 11       | 10    | 9        | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15 | ICC14    | ICC13    | ICC12    | ICC11    | ICC10 | ICC9     | ICC8 | ICC7  | ICC6 | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |
| W-0   | W-0      | W-0      | W-0      | W-0      | W-0   | W-0      | W-0  | W-0   | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  |
|       | D. D _ D | and only | 10/-10/r | to only: |       | oftor ro | cot  |       |      |      |      |      |      |      |      |

LEGEND: R = Read only; W = Write only; -n = Value after reset

## Figure 51. TX CPPI Interrupt Condition Status and Clear Registers

# TX CPPI Interrupt Condition Status Register (TX\_CPPI\_ICSR) (Address Offset 0250h)

| 31     |            |          |          |           |           |         |          |           |          |      |      |      |      |      | 16   |
|--------|------------|----------|----------|-----------|-----------|---------|----------|-----------|----------|------|------|------|------|------|------|
|        |            |          |          |           |           |         | Rese     | erved     |          |      |      |      |      |      |      |
|        |            |          |          |           |           |         | R        | -0        |          |      |      |      |      |      |      |
| 15     | 14         | 13       | 12       | 11        | 10        | 9       | 8        | 7         | 6        | 5    | 4    | 3    | 2    | 1    | 0    |
| ICS15  | ICS14      | ICS13    | ICS12    | ICS11     | ICS10     | ICS9    | ICS8     | ICS7      | ICS6     | ICS5 | ICS4 | ICS3 | ICS2 | ICS1 | ICS0 |
| R-0    | R-0        | R-0      | R-0      | R-0       | R-0       | R-0     | R-0      | R-0       | R-0      | R-0  | R-0  | R-0  | R-0  | R-0  | R-0  |
| TX CPP | Pl Interru | nt Condi | tion Cle | ar Regist | ter (TX ( | PPI ICO | CB) (Add | lress Off | set 0258 | h)   |      |      |      |      |      |
| 31     | 1 milen u  |          |          | ur regio  |           |         |          |           | 501 0200 | ,    |      |      |      |      | 16   |
|        |            |          |          |           |           |         | Rese     | erved     |          |      |      |      |      |      |      |
|        |            |          |          |           |           |         | R        | -0        |          |      |      |      |      |      |      |
| 15     | 14         | 13       | 12       | 11        | 10        | 9       | 8        | 7         | 6        | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15  | ICC14      | ICC13    | ICC12    | ICC11     | ICC10     | ICC9    | ICC8     | ICC7      | ICC6     | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |

W-0 LEGEND: R = Read only; W = Write only; -n = Value after reset

#### 4.3.3 LSU Interrupt Condition Status and Clear Registers

W-0

W-0

W-0

W-0

The ICSR and the ICCR for the LSUs are shown in Figure 52. These interrupt condition registers are used when the SRIO peripheral transmits direct I/O packets. As described in Table 36, each of the status and clear bits corresponds to a particular type of transaction interrupt condition for a particular LSU. The ICS bits of LSU ICSR indicate the occurrence of the conditions. The ICC bits of LSU ICCR are used to clear the corresponding ICS bits.

W-0



#### Interrupt Conditions

|          |           |           | F        | igure 5    | 52. LSU   | Interr     | upt Co    | ndition   | Status | s and C | lear R | egister | s     |       |       |
|----------|-----------|-----------|----------|------------|-----------|------------|-----------|-----------|--------|---------|--------|---------|-------|-------|-------|
| LSU Inte | errupt C  | ondition  | Status I | Register   | (LSU_IC   | SR) (Ad    | dress Of  | fset 0260 | Dh)    |         |        |         |       |       |       |
| 31       | 30        | 29        | 28       | 27         | 26        | 25         | 24        | 23        | 22     | 21      | 20     | 19      | 18    | 17    | 16    |
| ICS31    | ICS30     | ICS29     | ICS28    | ICS27      | ICS26     | ICS25      | ICS24     | ICS23     | ICS22  | ICS21   | ICS20  | ICS19   | ICS18 | ICS17 | ICS16 |
| R-0      | R-0       | R-0       | R-0      | R-0        | R-0       | R-0        | R-0       | R-0       | R-0    | R-0     | R-0    | R-0     | R-0   | R-0   | R-0   |
| 15       | 14        | 13        | 12       | 11         | 10        | 9          | 8         | 7         | 6      | 5       | 4      | 3       | 2     | 1     | 0     |
| ICS15    | ICS14     | ICS13     | ICS12    | ICS11      | ICS10     | ICS9       | ICS8      | ICS7      | ICS6   | ICS5    | ICS4   | ICS3    | ICS2  | ICS1  | ICS0  |
| R-0      | R-0       | R-0       | R-0      | R-0        | R-0       | R-0        | R-0       | R-0       | R-0    | R-0     | R-0    | R-0     | R-0   | R-0   | R-0   |
| LSU Inte | errupt C  | ondition  | Clear R  | egister (  | LSU_ICC   | R) (Add    | ress Offs | set 0268I | n)     |         |        |         |       |       |       |
| 31       | 30        | 29        | 28       | 27         | 26        | 25         | 24        | 23        | 22     | 21      | 20     | 19      | 18    | 17    | 16    |
| ICC31    | ICC30     | ICC29     | ICC28    | ICC27      | ICC26     | ICC25      | ICC24     | ICC23     | ICC22  | ICC21   | ICC20  | ICC19   | ICC18 | ICC17 | ICC16 |
| W-0      | W-0       | W-0       | W-0      | W-0        | W-0       | W-0        | W-0       | W-0       | W-0    | W-0     | W-0    | W-0     | W-0   | W-0   | W-0   |
| 15       | 14        | 13        | 12       | 11         | 10        | 9          | 8         | 7         | 6      | 5       | 4      | 3       | 2     | 1     | 0     |
| ICC15    | ICC14     | ICC13     | ICC12    | ICC11      | ICC10     | ICC9       | ICC8      | ICC7      | ICC6   | ICC5    | ICC4   | ICC3    | ICC2  | ICC1  | ICC0  |
| W-0      | W-0       | W-0       | W-0      | W-0        | W-0       | W-0        | W-0       | W-0       | W-0    | W-0     | W-0    | W-0     | W-0   | W-0   | W-0   |
| LEGENI   | D: R = Re | ead only; | W = Wri  | te only; - | n = Value | e after re | set       |           |        |         |        |         |       |       |       |

\_\_\_\_\_,

# Table 36. Interrupt Conditions Shown in LSU\_ICSR and Cleared With LSU\_ICCR

| Bit | Associated LSU | Interrupt Condition                                                                         |
|-----|----------------|---------------------------------------------------------------------------------------------|
| 31  | LSU4           | Packet not sent due to unavailable outbound credit at given priority                        |
| 30  | LSU4           | Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use) |
| 29  | LSU4           | Transaction was not sent due to DMA data transfer error                                     |
| 28  | LSU4           | Transaction timeout occurred                                                                |
| 27  | LSU4           | Transaction was not sent due to unsupported transaction type or invalid field encoding      |
| 26  | LSU4           | Transaction was not sent due to Xoff condition                                              |
| 25  | LSU4           | Non-posted transaction received ERROR response, or error in response payload                |
| 24  | LSU4           | Transaction complete, No errors (posted/non-posted) <sup>(1)</sup>                          |
| 23  | LSU3           | Packet not sent due to unavailable outbound credit at given priority                        |
| 22  | LSU3           | Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use) |
| 21  | LSU3           | Transaction was not sent due to DMA data transfer error                                     |
| 20  | LSU3           | Transaction timeout occurred                                                                |
| 19  | LSU3           | Transaction was not sent due to unsupported transaction type or invalid field encoding      |
| 18  | LSU3           | Transaction was not sent due to Xoff condition                                              |
| 17  | LSU3           | Non-posted transaction received ERROR response, or error in response payload                |
| 16  | LSU3           | Transaction complete, No errors (posted/non-posted) <sup>(1)</sup>                          |
| 15  | LSU2           | Packet not sent due to unavailable outbound credit at given priority                        |
| 14  | LSU2           | Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use) |
| 13  | LSU2           | Transaction was not sent due to DMA data transfer error                                     |
| 12  | LSU2           | Transaction timeout occurred                                                                |
| 11  | LSU2           | Transaction was not sent due to unsupported transaction type or invalid field encoding      |
| 10  | LSU2           | Transaction was not sent due to Xoff condition                                              |
| 9   | LSU2           | Non-posted transaction received ERROR response, or error in response payload                |
| 8   | LSU2           | Transaction complete, No errors (posted/non-posted) <sup>(1)</sup>                          |
| 7   | LSU1           | Packet not sent due to unavailable outbound credit at given priority                        |

(1) Enable for this interrupt is ultimately controlled by the Interrupt Req register bit of LSUn\_REG4. This allows enabling/disabling on a per request basis. For optimum LSU performance, interrupt pacing should not be used on the LSU interrupts. Section 4.7 describes interrupt pacing.

16

ICC16

17

| Bit | Associated LSU | Interrupt Condition                                                                         |
|-----|----------------|---------------------------------------------------------------------------------------------|
| 6   | LSU1           | Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use) |
| 5   | LSU1           | Transaction was not sent due to DMA data transfer error                                     |
| 4   | LSU1           | Transaction timeout occurred                                                                |
| 3   | LSU1           | Transaction was not sent due to unsupported transaction type or invalid field encoding      |
| 2   | LSU1           | Transaction was not sent due to Xoff condition                                              |
| 1   | LSU1           | Non-posted transaction received ERROR response, or error in response payload                |
| 0   | LSU1           | Transaction complete, No errors (posted/non-posted) <sup>(1)</sup>                          |

# Table 36. Interrupt Conditions Shown in LSU\_ICSR and Cleared With LSU\_ICCR (continued)

## 4.3.4 Error, Reset, and Special Event Interrupt Condition Status and Clear Registers

The ICSR and the ICCR for the SRIO ports are shown in Figure 53. As described in Table 37, each of the nonreserved status and clear bits corresponds to a particular interrupt condition in one or more of the SRIO ports. The ICS bits of ERR\_RST\_EVNT\_ICSR indicate the occurrence of the conditions. The ICC bits of ERR\_RST\_EVNT\_ICCR are used to clear the corresponding ICS bits.

# Figure 53. Error, Reset, and Special Event Interrupt Condition Status and Clear Registers Error, Reset, and Special Event Interrupt Condition Status Register (ERR\_RST\_EVNT\_ICSR) (Address Offset 0270h)

| 31 |          |    |       |       |      |         |   |          |   |      | 17   | 16    |
|----|----------|----|-------|-------|------|---------|---|----------|---|------|------|-------|
|    |          |    |       |       |      | Reserve | d |          |   |      |      | ICS16 |
|    |          |    |       |       |      | R-0     |   |          |   |      |      | R-0   |
| 15 |          | 12 | 11    | 10    | 9    | 8       | 7 |          | 3 | 2    | 1    | 0     |
|    | Reserved |    | ICS11 | ICS10 | ICS9 | ICS8    |   | Reserved |   | ICS2 | ICS1 | ICS0  |
|    | R-0      |    | R-0   | R-0   | R-0  | R-0     |   | R-0      |   | R-0  | R-0  | R-0   |

Error, Reset, and Special Event Interrupt Condition Clear Register (ERR\_RST\_EVNT\_ICCR) (Address Offset 0278h)
31
Reserved

|    |       |       |             | R-0              |                                                                                                      |                                                                                                                          |                                                                                                                                 |                                                                                               |                                                                                                                                        | W-0                                                                                                                                                       |
|----|-------|-------|-------------|------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12 | 11    | 10    | 9           | 8                | 7                                                                                                    |                                                                                                                          | 3                                                                                                                               | 2                                                                                             | 1                                                                                                                                      | 0                                                                                                                                                         |
|    | ICC11 | ICC10 | ICC9        | ICC8             | F                                                                                                    | Reserved                                                                                                                 |                                                                                                                                 | ICC2                                                                                          | ICC1                                                                                                                                   | ICC0                                                                                                                                                      |
|    | W-0   | W-0   | W-0         | W-0              |                                                                                                      | R-0                                                                                                                      |                                                                                                                                 | W-0                                                                                           | W-0                                                                                                                                    | W-0                                                                                                                                                       |
|    | 12    | ICC11 | ICC11 ICC10 | ICC11 ICC10 ICC9 | 12         11         10         9         8           ICC11         ICC10         ICC9         ICC8 | 12         11         10         9         8         7           ICC11         ICC10         ICC9         ICC8         F | 12         11         10         9         8         7           ICC11         ICC10         ICC9         ICC8         Reserved | 12     11     10     9     8     7     3       ICC11     ICC10     ICC9     ICC8     Reserved | 12       11       10       9       8       7       3       2         ICC11       ICC10       ICC9       ICC8       Reserved       ICC2 | 12       11       10       9       8       7       3       2       1         ICC11       ICC10       ICC9       ICC8       Reserved       ICC2       ICC1 |

LEGEND: R = Read only; W = Write only; -n = Value after reset

# Table 37. Interrupt Conditions Shown in ERR\_RST\_EVNT\_ICSR and Cleared With ERR\_RST\_EVNT\_ICCR

| Bit   | Interrupt Condition                                            |
|-------|----------------------------------------------------------------|
| 31–17 | Reserved                                                       |
| 16    | Device reset interrupt from any port                           |
| 15–12 | Reserved                                                       |
| 11    | Port 3 error (TMS320TCI6482 Only)                              |
| 10    | Port 2 error (TMS320TCI6482 Only)                              |
| 9     | Port 1 error                                                   |
| 8     | Port 0 error                                                   |
| 7–3   | Reserved                                                       |
| 2     | Logical layer error management event capture                   |
| 1     | Port-write-in request received on any port                     |
| 0     | Multi-cast event control symbol interrupt received on any port |

Interrupt Conditions

The interrupt status bits found in the ERR\_RST\_EVNT (0x0270) can be cleared by writing to the ICCR register (0x0278) in the same manner as other interrupts. However, in order for new event detection and interrupt generation to occur for these special interrupts, additional register bits must be cleared. The following table notes the additional interrupt source register bits that need to be cleared and the appropriated sequence. These are all the bits that can cause the ERR\_RST\_EVNT status bits to be set

|                                      | 1 0 1                 | •                                                    | •                    |
|--------------------------------------|-----------------------|------------------------------------------------------|----------------------|
| Interrupt Function                   | 1 <sup>st</sup> Step  | 2 <sup>nd</sup> Step                                 | 3 <sup>rd</sup> Step |
| Multicast Event Control Symbol       | Write 1 to clear:     | Write 1 to clear:                                    |                      |
| received on any port                 | Offset 0x0278         | Offset 0x12004                                       |                      |
|                                      | ERR_RST_EVNT_ICCR[0]  | SP_IP_MODE[4]                                        |                      |
| Port Write In Request received       | Write 1 to clear:     | Write 1 to clear:                                    |                      |
| on any port                          | Offset 0x0278         | Offset 0x12004                                       |                      |
|                                      | ERR_RST_EVNT_ICCR[1]  | SP_IP_MODE[0]                                        |                      |
| Port 0 Error                         | Write 1 to clear:     | Write 1 to clear any of the following possible bits: | Write 1 to clear:    |
|                                      | Offset 0x0278         | Offset 0x2040                                        | Offset 0x14004       |
|                                      | ERR_RST_EVNT_ICCR[8]  | SP0_ERR_STAT[2] – Fatal<br>error                     | SP0_CTL_INDEP[6]     |
|                                      |                       | SP0_ERR_STAT[25] – Failed<br>Threshold               |                      |
|                                      |                       | SP0_ERR_STAT[24] –<br>Degraded Threshold             |                      |
|                                      |                       | Offset 0x14004                                       |                      |
|                                      |                       | SP0_CTL_INDEP[20] – Illegal<br>Transaction           |                      |
|                                      |                       | SP0_CTL_INDEP[16] – Max<br>Retry Error               |                      |
| Port 1 Error                         | Write 1 to clear:     | Write 1 to clear any of the following possible bits: | Write 1 to clear:    |
|                                      | Offset 0x0278         | Offset 0x2080                                        | Offset 0x14104       |
|                                      | ERR_RST_EVNT_ICCR[9]  | SP1_ERR_STAT[2] – Fatal<br>error                     | SP1_CTL_INDEP[6]     |
|                                      |                       | SP1_ERR_STAT[25] – Failed<br>Threshold               |                      |
|                                      |                       | SP1_ERR_STAT[24] –<br>Degraded Threshold             |                      |
|                                      |                       | Offset 0x14104                                       |                      |
|                                      |                       | SP1_CTL_INDEP[20] – Illegal<br>Transaction           |                      |
|                                      |                       | SP1_CTL_INDEP[16] – Max<br>Retry Error               |                      |
| Port 2 Error<br>(TMS320TCI6482 Only) | Write 1 to clear:     | Write 1 to clear any of the following possible bits: | Write 1 to clear:    |
|                                      | Offset 0x0278         | Offset 0x20C0                                        | Offset 0x14204       |
|                                      | ERR_RST_EVNT_ICCR[10] | SP2_ERR_STAT[2] – Fatal<br>error                     | SP2_CTL_INDEP[6]     |
|                                      |                       | SP2_ERR_STAT[25] – Failed<br>Threshold               |                      |
|                                      |                       | SP2_ERR_STAT[24] –<br>Degraded Threshold             |                      |
|                                      |                       | Offset 0x14204                                       |                      |
|                                      |                       | SP2_CTL_INDEP[20] – Illegal<br>Transaction           |                      |
|                                      |                       | SP2_CTL_INDEP[16] – Max                              |                      |

## Table 38. Interrupt Clearing Sequence for Special Event Interrupts

| Interrupt Function                   | 1 <sup>st</sup> Step  | 2 <sup>nd</sup> Step                                 | 3 <sup>rd</sup> Step |
|--------------------------------------|-----------------------|------------------------------------------------------|----------------------|
| Port 3 Error<br>(TMS320TCl6482 Only) | Write 1 to clear:     | Write 1 to clear any of the following possible bits: | Write 1 to clear:    |
|                                      | Offset 0x0278         | Offset 0x2100                                        | Offset 0x14304       |
|                                      | ERR_RST_EVNT_ICCR[11] | SP3_ERR_STAT[2] – Fatal<br>error                     | SP_CTL_INDEP[6]      |
|                                      |                       | SP3_ERR_STAT[25] – Failed<br>Threshold               |                      |
|                                      |                       | SP3_ERR_STAT[24] –<br>Degraded Threshold             |                      |
|                                      |                       | Offset 0x14304                                       |                      |
|                                      |                       | SP3_CTL_INDEP[20] – Illegal<br>Transaction           |                      |
|                                      |                       | SP3_CTL_INDEP[16] – Max<br>Retry Error               |                      |
| Device Reset                         | Write 1 to clear:     | Write 1 to clear:                                    |                      |
|                                      | Offset 0x0278         | Offset 0x12004                                       |                      |
|                                      | ERR_RST_EVNT_ICCR[16] | SP_IP_MODE[2]                                        |                      |

## Table 38. Interrupt Clearing Sequence for Special Event Interrupts (continued)

# 4.4 Interrupt Condition Routing Registers

The interrupt conditions are programmable to select the interrupt output that will be driven. Using the interrupt condition routing registers (ICRRs), software can independently route each interrupt request to any of the interrupt destinations supported by the device. For example, a quad core device may support four CPU servicing interrupt destinations, one per core (INTDST0 for Core0, INTDST1 for Core1, INTDST2 for Core2, and INTDST3 for Core3). In addition, INTDST4 may be globally routed to all cores and provide notification of a change in the one ICSR, while INTDST5 may be globally routed to all cores and provide notification of a change in a different ICSR. The routing defaults for an interrupt condition routing bit (ICRx) are given in Table 39.

| Field | Access | Reset Value | Value | Function                                            |
|-------|--------|-------------|-------|-----------------------------------------------------|
| ICRx  | R      | 0000b       | 0000b | Routed to INTDST0                                   |
|       |        |             | 0001b | Routed to INTDST1                                   |
|       |        |             | 0010b | Routed to INTDST2                                   |
|       |        |             | 0011b | Routed to INTDST3                                   |
|       |        |             | 0100b | Routed to INTDST4                                   |
|       |        |             | 0101b | Routed to INTDST5                                   |
|       |        |             | 0110b | Routed to INTDST6                                   |
|       |        |             | 0111b | Routed to INTDST7                                   |
|       |        |             | 1111b | No interrupt destination, interrupt source disabled |
|       |        |             | other | Reserved                                            |

# **Table 39. Interrupt Condition Routing Options**

# 4.4.1 Doorbell Interrupt Condition Routing Registers

Figure 54 shows the interrupt condition routing registers for Doorbell 0. The other doorbell ICRRs have the same bit field map, with the following addresses:

- DOORBELL1\_ICRR and DOORBELL1\_ICCR2 (Address offsets 0290h and 0294h)
- DOORBELL2\_ICRR and DOORBELL2\_ICRR2 (Address offset 02A0h and 02A4h)
- DOORBELL3\_ICRR and DOORBELL3\_ICRR2 (Address offset 02B0h and 02B4h)



When doorbell packets are received by the SRIO peripheral, these ICRRs route doorbell interrupt requests to interrupt destinations. For example, if ICS6 = 1 in DOORBELL2\_ICSR and ICR6 = 0010b in DOORBELL2\_ICRR, the interrupt request from Doorbell 2, bit 6 is sent to interrupt destination 2.

# Figure 54. Doorbell 0 Interrupt Condition Routing Registers

Doorbell 0 Interrupt Condition Routing Register (DOORBELL0\_ICRR) (Address Offset 0280h)

|    | •        | -     |          | , ,   |          |       |          |    |
|----|----------|-------|----------|-------|----------|-------|----------|----|
| 31 |          | 28 27 |          | 24 23 |          | 20 19 |          | 16 |
|    | ICR7     |       | ICR6     |       | ICR5     |       | ICR4     |    |
|    | R/W-0000 |       | R/W-0000 |       | R/W-0000 |       | R/W-0000 |    |
| 15 |          | 12 11 |          | 87    |          | 4 3   |          | 0  |
|    | ICR3     |       | ICR2     |       | ICR1     |       | ICR0     |    |
|    | R/W-0000 |       | R/W-0000 |       | R/W-0000 |       | R/W-0000 |    |

#### Doorbell 0 Interrupt Condition Routing Register 2 (DOORBELL0\_ICRR2) (Address Offset 0284h)

| 31 |          | 28 27 |          | 24 23 |          | 20 19 |          | 16 |
|----|----------|-------|----------|-------|----------|-------|----------|----|
|    | ICR15    |       | ICR14    |       | ICR13    |       | ICR12    |    |
|    | R/W-0000 |       | R/W-0000 |       | R/W-0000 |       | R/W-0000 |    |
| 15 |          | 40 44 |          | 0 7   |          |       |          |    |
| 15 |          | 12 11 |          | 87    |          | 4 3   |          | 0  |
| 15 | ICR11    | 12 11 | ICR10    | 8 /   | ICR9     | 4 3   | ICR8     | 0  |

LEGEND: R/W = Read/Write; -n = Value after reset

# 4.4.1.1 CPPI Interrupt Condition Routing Registers

Figure 55 shows the ICRRs for the RXU, and Figure 56 shows the ICRRs for the TXU. These registers route queue interrupts to interrupt destinations. For example, if ICS6 = 1 in RX\_CPPI\_ICSR and ICR6 = 0010b in RX\_CPPI\_ICRR, the interrupt request from RX buffer descriptor queue 6 is sent to interrupt destination 2. Similarly, if ICS6 = 1 in TX\_CPPI\_ICSR and ICR6 = 0011b in TX\_CPPI\_ICRR, the interrupt request from TX buffer descriptor queue 6 is sent to interrupt destination 3.

# Figure 55. RX CPPI Interrupt Condition Routing Registers

#### RX CPPI Interrupt Condition Routing Register (RX\_CPPI\_ICRR) (Address Offset 02C0h)

| 20 19 16          |
|-------------------|
| ICR5 ICR4         |
| R/W-0000 R/W-0000 |
| 4 3 0             |
| ICR1 ICR0         |
|                   |
|                   |

#### RX CPPI Interrupt Condition Routing Register 2 (RX\_CPPI\_ICRR2) (Address Offset 02C4h)

| 31 |          | 28 | 27 |          | 24 | 23 |          | 20 | 19       | 16 |
|----|----------|----|----|----------|----|----|----------|----|----------|----|
|    | ICR15    |    |    | ICR14    |    |    | ICR13    |    | ICR12    |    |
|    | R/W-0000 |    |    | R/W-0000 |    |    | R/W-0000 |    | R/W-0000 |    |
| 15 |          | 12 | 11 |          | 8  | 7  |          | 4  | 3        | 0  |
|    | ICR11    |    |    | ICR10    |    |    | ICR9     |    | ICR8     |    |
|    | R/W-0000 |    |    | R/W-0000 |    |    | R/W-0000 |    | R/W-0000 |    |
|    |          |    |    |          |    |    |          |    |          |    |

LEGEND: R/W = Read/Write; -*n* = Value after reset

| 31                                                 | 28       | 27                                                  | 24 23                  |                              | 20 | 19      |           | 16 |
|----------------------------------------------------|----------|-----------------------------------------------------|------------------------|------------------------------|----|---------|-----------|----|
| ICR7                                               |          | ICR6                                                |                        | ICR5                         |    |         | ICR4      |    |
| R/W-0000                                           |          | R/W-0000                                            |                        | R/W-0000                     |    |         | R/W-0000  |    |
| 15                                                 | 12       | 11                                                  | 87                     |                              | 4  | 3       |           | 0  |
| ICR3                                               |          | ICR2                                                |                        | ICR1                         |    |         | ICR0      |    |
| R/W-0000                                           |          | R/W-0000                                            |                        | D/// 0000                    |    |         | D/// 0000 |    |
| 10/00/0000                                         |          | R/W-0000                                            |                        | R/W-0000                     |    |         | R/W-0000  |    |
|                                                    | tion Rou | Iting Register 2 (TX_CPF                            | I_ICRR2) (Add          |                              |    |         | R/W-0000  |    |
| TX CPPI Interrupt Condi                            |          |                                                     | 1_ICRR2) (Add<br>24 23 |                              | 20 | 19      | R/W-0000  | 16 |
| TX CPPI Interrupt Condi                            |          | uting Register 2 (TX_CPP                            |                        |                              | 20 | 19      | ICR12     | 16 |
| TX CPPI Interrupt Condi                            |          | uting Register 2 (TX_CPP                            |                        | dress Offset 02D4h)          | 20 | 19      |           | 16 |
| TX CPPI Interrupt Condi<br>31<br>ICR15<br>R/W-0000 | 28       | tting Register 2 (TX_CPP<br>27<br>ICR14             |                        | dress Offset 02D4h)<br>ICR13 |    | 19<br>3 | ICR12     | 16 |
| TX CPPI Interrupt Condi<br>31<br>ICR15             | 28       | ating Register 2 (TX_CPP<br>27<br>ICR14<br>R/W-0000 | 24 23                  | dress Offset 02D4h)<br>ICR13 |    | _       | ICR12     |    |

LEGEND: R/W = Read/Write; -*n* = Value after reset

# 4.4.1.2 LSU Interrupt Condition Routing Registers

Figure 57 shows the ICRRs for the LSU interrupt requests. These registers route LSU interrupt requests to interrupt destinations. For example, if ICS4 = 1 in LSU\_ICSR and ICR4 = 0000b in LSU\_ICRR0, LSU1 has generated a transaction-timeout interrupt request, and that request is routed to interrupt destination 0.



Interrupt Conditions

| 31                              |                                                              | 28                        | 27                                                                                                                                                                                                  | 24                                   | 23                                                                                                                 | 20 | 19 |                                                 | 16 |
|---------------------------------|--------------------------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------|----|----|-------------------------------------------------|----|
|                                 | ICR7                                                         |                           | ICR6                                                                                                                                                                                                |                                      | ICR5                                                                                                               |    |    | ICR4                                            |    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                            |                                      | R/W-0000                                                                                                           |    |    | R/W-0000                                        |    |
| 15                              |                                                              | 12                        | 11                                                                                                                                                                                                  | 8                                    | 7                                                                                                                  | 4  | 3  |                                                 | 0  |
|                                 | ICR3                                                         |                           | ICR2                                                                                                                                                                                                |                                      | ICR1                                                                                                               |    |    | ICR0                                            |    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                            |                                      | R/W-0000                                                                                                           |    |    | R/W-0000                                        |    |
| LSU lı                          | nterrupt Condition                                           | Routing                   | Register 1 (LSU_ICR                                                                                                                                                                                 | R1) (Address                         | s Offset 02E4h)                                                                                                    |    |    |                                                 |    |
| 31                              |                                                              | 28                        | 27                                                                                                                                                                                                  | 24                                   | 23                                                                                                                 | 20 | 19 |                                                 | 16 |
|                                 | ICR15                                                        |                           | ICR14                                                                                                                                                                                               |                                      | ICR13                                                                                                              |    |    | ICR12                                           |    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                            |                                      | R/W-0000                                                                                                           |    |    | R/W-0000                                        |    |
| 15                              |                                                              | 12                        | 11                                                                                                                                                                                                  | 8                                    | 7                                                                                                                  | 4  | 3  |                                                 | 0  |
|                                 | ICR11                                                        |                           | ICR10                                                                                                                                                                                               |                                      | ICR9                                                                                                               |    |    | ICR8                                            |    |
|                                 |                                                              |                           |                                                                                                                                                                                                     |                                      |                                                                                                                    |    |    |                                                 |    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                            |                                      | R/W-0000                                                                                                           |    |    | R/W-0000                                        |    |
| LSU lr                          |                                                              | Routing                   | R/W-0000<br>Register 2 (LSU_ICRI                                                                                                                                                                    | R2) (Address                         |                                                                                                                    |    |    | R/W-0000                                        |    |
|                                 |                                                              | -                         |                                                                                                                                                                                                     | <b>R2) (Addres</b> s<br>24           | s Offset 02E8h)                                                                                                    | 20 | 19 | R/W-0000                                        | 16 |
|                                 |                                                              | -                         | Register 2 (LSU_ICR                                                                                                                                                                                 | , ,                                  | s Offset 02E8h)                                                                                                    | 20 | 19 | R/W-0000                                        | 16 |
|                                 | nterrupt Condition                                           | -                         | Register 2 (LSU_ICR                                                                                                                                                                                 | , ,                                  | s Offset 02E8h)<br>23                                                                                              | 20 | 19 |                                                 | 16 |
| 31                              | ICR23                                                        | -                         | Register 2 (LSU_ICRF<br>27<br>ICR22<br>R/W-0000                                                                                                                                                     | , ,                                  | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000                                                                         | 20 |    | ICR20                                           | 16 |
| 31                              | ICR23                                                        | 28                        | Register 2 (LSU_ICRF<br>27<br>ICR22<br>R/W-0000                                                                                                                                                     | 24                                   | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000                                                                         |    |    | ICR20                                           |    |
| 31                              | ICR23<br>R/W-0000                                            | 28                        | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11                                                                                                                   | 24                                   | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7                                                                    |    |    | ICR20<br>R/W-0000                               |    |
| 31<br>15                        | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000                       | 12                        | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11           ICR18                                                                                                   | 8                                    | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7<br>ICR17<br>R/W-0000                                               |    |    | ICR20<br>R/W-0000<br>ICR16                      |    |
| 31<br>15<br>LSU Ir              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000                       | 28<br>12<br>Routing       | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11           ICR18           R/W-0000                                                                                | 8                                    | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7<br>ICR17<br>R/W-0000<br>s Offset 02ECh)                            | 4  |    | ICR20<br>R/W-0000<br>ICR16                      |    |
| 31<br>15<br>LSU Ir              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000                       | 28<br>12<br>Routing       | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11           ICR18           R/W-0000           Register 3 (LSU_ICRI                                                 | 24<br>8<br>R3) (Address              | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7<br>ICR17<br>R/W-0000<br>s Offset 02ECh)                            | 4  | 3  | ICR20<br>R/W-0000<br>ICR16                      | 0  |
| 31<br>15<br>LSU Ir              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000<br>hterrupt Condition | 28<br>12<br>Routing       | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11           ICR18           R/W-0000           Register 3 (LSU_ICRI           27                                    | 24<br>8<br>R3) (Address              | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7<br>ICR17<br>R/W-0000<br>s Offset 02ECh)<br>23                      | 4  | 3  | ICR20<br>R/W-0000<br>ICR16<br>R/W-0000          | 0  |
| 31<br>15<br><b>LSU li</b><br>31 | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000<br>nterrupt Condition | 28<br>12<br>Routing       | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11           ICR18           R/W-0000           Register 3 (LSU_ICRI           27           ICR30           R/W-0000 | 24<br>8<br>R3) (Address              | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7<br>ICR17<br>R/W-0000<br>s Offset 02ECh)<br>23<br>ICR29<br>R/W-0000 | 20 | 3  | ICR20<br>R/W-0000<br>ICR16<br>R/W-0000<br>ICR28 | 0  |
| 31                              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000<br>nterrupt Condition | 28<br>12<br>Routing<br>28 | Register 2 (LSU_ICRI           27           ICR22           R/W-0000           11           ICR18           R/W-0000           Register 3 (LSU_ICRI           27           ICR30           R/W-0000 | 24<br>8<br><b>R3) (Address</b><br>24 | s Offset 02E8h)<br>23<br>ICR21<br>R/W-0000<br>7<br>ICR17<br>R/W-0000<br>s Offset 02ECh)<br>23<br>ICR29<br>R/W-0000 | 20 | 3  | ICR20<br>R/W-0000<br>ICR16<br>R/W-0000<br>ICR28 | 0  |

LEGEND: R/W = Read/Write; -*n* = Value after reset

# 4.4.1.3 Error, Reset, and Special Event Interrupt Condition Routing Registers

The ICRRs shown in Figure 58 route port interrupt requests to interrupt destinations. For example, if ICS8 = 1 in ERR\_RST\_EVNT\_ICSR and ICR8 = 0001b in ERR\_RST\_EVNT\_ICRR2, port 0 has generated an error interrupt request, and that request is routed to interrupt destination 1.

# Figure 58. Error, Reset, and Special Event Interrupt Condition Routing Registers Error, Reset, and Special Event ICRR (ERR RST EVNT ICRR) (Address Offset 02F0h)

| 31                               | ·                       | <i>,</i> , , | ,                 |                   |          |    |
|----------------------------------|-------------------------|--------------|-------------------|-------------------|----------|----|
|                                  |                         | Reserved     |                   |                   |          |    |
|                                  |                         | R-0          |                   |                   |          |    |
| 12                               | 11                      | 87           |                   | 4 3               |          | 0  |
| Reserved                         | served ICR2 ICR1        |              | ICR1              | ICR0              |          |    |
| R-0                              | R/W-0000                |              | R/W-0000          | R/W-0000 R/W-0000 |          |    |
| Error, Reset, & Special Event IC | RR 2 (ERR_RST_EVNT_ICR  | R2) (Address | s Offset 02F4h)   |                   |          |    |
| 31                               | -                       |              |                   |                   |          | 16 |
|                                  |                         | Reserved     |                   |                   |          |    |
|                                  |                         | R-0          |                   |                   |          |    |
| 15 12                            | 11                      | 87           |                   | 4 3               |          | 0  |
| ICR11                            | ICR10                   |              | ICR9              |                   | ICR8     |    |
| R/W-0000                         | R/W-0000                |              | R/W-0000          |                   | R/W-0000 |    |
| Error, Reset, and Special Event  | ICRR 3 (ERR_RST_EVNT_IC | CRR3) (Addre | ess Offset 02F8h) |                   |          |    |
| 31                               |                         |              |                   |                   |          |    |
|                                  |                         | Reserved     |                   |                   |          |    |
|                                  |                         | R-0          |                   |                   |          |    |
|                                  |                         |              |                   | 4 3               |          | 0  |
|                                  | Reserved                |              |                   |                   | ICR16    |    |
|                                  | R-0                     |              |                   | ·                 | R/W-0000 |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

# 4.5 Interrupt Status Decode Registers

There are 8 blocks of the ICSRs to indicate the source of a pending interrupt.

0x0200: Doorbell0 interrupts 0x0210: Doorbell1 interrupts 0x0220: Doorbell2 interrupts 0x0230: Doorbell3 interrupts 0x0240: RX CPPI interrupts 0x0250: TX CPPI interrupts 0x0260: LSU interrupts 0x0270: Error, Reset, and Special Event interrupts

To reduce the number of reads (up to 5 reads) required to find the source bit, an Interrupt Status Decode Register (ISDR) is implemented for each supported physical interrupt destination. The device supports up to eight interrupt destinations, INTDST0–INTDST7. The names of the ISDRs and their address offsets are:

- INTDST0\_DECODE (Address offset 0300h)
- INTDST1\_DECODE (Address offset 0304h)
- INTDST2\_DECODE (Address offset 0308h)
- INTDST3\_DECODE (Address offset 030Ch)
- INTDST4 DECODE (Address offset 0310h)
- INTDST5\_DECODE (Address offset 0314h)
- INTDST6\_DECODE (Address offset 0318h)
- INTDST7\_DECODE (Address offset 031Ch)

Aside from supporting different interrupt destinations, the ISDRs are the same in content and functionality. The register fields are shown in Figure 59. Figure 60 shows which interrupt sources can be mapped to



#### Interrupt Conditions

each bit in the ISDR. Bits within the LSU interrupt condition status register (ICSR) are logically grouped for a given core and ORed together into a single bit (bit 31) of the decode register. Similarly, the bits within the Error, Reset, and Special Event ICSR are ORed together into bit 30 of the decode register. The TX CPPI and RX CPPI interrupt sources (one for each buffer descriptor queue) can be mapped to bits 31–16 as shown in Figure 60. The doorbell interrupt sources can be mapped to bits 15–0.

An interrupt source is mapped to ISDR bits only if the ICRR for that interrupt source routes it to the corresponding interrupt destination. When multiple interrupt sources are mapped to the same bit, the bit status is a logical OR of those interrupt sources. The mapping of interrupt source bits to decode bits is fixed and is not programmable.

|       |       |       |       | ja. 0 00 |       |       |       |       |       |       |       |       |       |       |       |
|-------|-------|-------|-------|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 31    | 30    | 29    | 28    | 27       | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| ISD31 | ISD30 | ISD29 | ISD28 | ISD27    | ISD26 | ISD25 | ISD24 | ISD23 | ISD22 | ISD21 | ISD20 | ISD19 | ISD18 | ISD17 | ISD16 |
| R-0   | R-0   | R-0   | R-0   | R-0      | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   |
| 15    | 14    | 13    | 12    | 11       | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| ISD15 | ISD14 | ISD13 | ISD12 | ISD11    | ISD10 | ISD9  | ISD8  | ISD7  | ISD6  | ISD5  | ISD4  | ISD3  | ISD2  | ISD1  | ISD0  |
| R-0   | R-0   | R-0   | R-0   | R-0      | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   |

#### Figure 59. Interrupt Status Decode Register (INTDST*n*\_DECODE)

LEGEND: R = Read only; -n = Value after reset

# Figure 60. Interrupt Sources Assigned to ISDR Bits



- A Please note that bits 0 through 15 of this ICSR correspond to bits 31 through 16 of the ISDR. For example, bit 15 of the ICSR corresponds to bit 31 of the ISDR, and so on.
- B Please note that bits 15 through 0 of this ICSR correspond to bits 15 through 0 of the ISDR. For example, bit 15 of the ICSR corresponds to bit 15 of the ISDR, and so on.

As an example of reading an ISDR, if bit 29 of the ISDR is set, this indicates that there is a pending interrupt on either the TX CPPI queue 2 or RX CPPI queue 2. Figure 61 illustrates the decode routing for this example.





Figure 61. Example Diagram of Interrupt Status Decode Register Mapping

The following are suggestions for minimizing the number of register reads to identifying the interrupt source:

- Dedicate each doorbell ICSR to one core. The CPU can then determine the interrupt source from a single read of the decode register.
- Assign the RX and TX CPPI queues orthogonally to different cores. The CPU can then determine the interrupt source from a single read of the decode registers. The only exceptions to this are bits 31 and 30, which are also logically ORed with LSU and port interrupt sources.

# 4.6 Interrupt Generation

Interrupts are triggered on a 0-to-1 logic-signal transition. Regardless of the interrupt sources, the physical interrupts are set only when the total number of set ICSR bits transitions from none to one or more. The peripheral is responsible for setting the correct bit within the ICSR. The ICRR register maps the pending interrupt request to the appropriate physical interrupt line. The corresponding CPU is interrupted and reads the ISDR and ICSR registers to determine the interrupt source and appropriate action. Interrupt generation is governed by the interrupt pacing discussed Section 4.7.

# 4.7 Interrupt Pacing

The rate at which an interrupt can be generated is controllable for each physical interrupt destination. Rate control is implemented with a programmable down-counter. The load value of the counter is written by the CPU into the appropriate interrupt rate control register (see Figure 62). The counter reloads and



0

#### Interrupt Conditions

immediately starts down-counting each time the CPU writes these registers. When the rate control counter register is written, and the counter value reaches zero (note that the CPU may write zero immediately for a zero count), the interrupt pulse generation logic is allowed to fire a single pulse if any bits in the corresponding ICSR register bits are set (or become set after the zero count is reached). The counter remains at zero. When the single pulse is generated, the logic will not generate another pulse, regardless of interrupt status changes, until the rate control counter register is written again.

An interrupt rate control register (INTDST*n*\_RATE\_CNTL) is implemented for each supported physical interrupt destination. The device supports up to eight interrupt destinations, INTDST0–INTDST7. The names of the registers and their address offsets are:

- INTDST0\_RATE\_CNTL (Address offset 0320h)
- INTDST1\_RATE\_CNTL (Address offset 0324h)
- INTDST2\_RATE\_CNTL (Address offset 0328h)
- INTDST3 RATE CNTL (Address offset 032Ch)
- INTDST4 RATE CNTL (Address offset 0330h)
- INTDST5 RATE CNTL (Address offset 0334h)
- INTDST6\_RATE\_CNTL (Address offset 0338h)
- INTDST7 RATE CNTL (Address offset 033Ch)

If interrupt pacing is not desired for a particular interrupt destination, the CPU must still write 00000000h into the INTDST*n*\_RATE\_CNTL register after clearing the corresponding ICSR bits to acknowledge the physical interrupt. If an ICSR is not mapped to an interrupt destination, pending interrupt bits within the ICSR maintain current status. When enabled, the interrupt logic re-evaluates all pending interrupts and re-pulses the interrupt signal if any interrupt conditions are pending. The down-counter is based on the DMA clock cycle.

## Figure 62. INTDSTn\_RATE\_CNTL Interrupt Rate Control Register

31

32-bit Count Down Value R/W-0

LEGEND: R/W = Read/Write; -n = Value after reset

# 4.8 Interrupt Handling

Interrupts are either signaled externally through RapidIO packets, or internally by state machines in the peripheral. CPU servicing interrupts are signaled externally by the DOORBELL RapidIO packet in direct I/O mode, or internally by the CPPI module in the message passing mode. Error Status interrupts are signaled when error counting logic within the peripheral have reached their thresholds. In either case, it is the peripheral that signals the interrupt and sets the corresponding status bits.

When the CPU is interrupted, it reads the ICSR registers to determine the source of the interrupt and appropriate action to take. For example, if it is a DOORBELL interrupt, the CPU will read from an L2 address that is specified by its circular buffer read pointer that is managed by software. There may be more than one circular buffer for each core. The correct circular buffer to read from and increment depends on the bit set in the ICSR register. The CPU then clears the status bit.

For Error Status interrupts, the peripheral must indicate to all the CPUs that one of the link ports has reached the error threshold. In this case, the peripheral sets the status bit indicating degraded or failed limits have been reached, and an interrupt is generated to each core through the ICRR mapping. The cores can then scan the ICSR registers to determine the port with the error problems. Further action can then be taken as determined by the application.

```
Interrupt Handler
temp1 = SRIO_REGS->TX_CPPI_ICSR;
 if ((temp1 & 0x0000001) == 0x00000001)
  {
          SRIO_REGS->Queue0_TXDMA_CP = (int )TX_DESCP0_0;
  }
temp2 = SRIO_REGS->RX_CPPI_ICSR;
 if ((temp2 & 0x0000001) == 0x00000001)
  {
          SRIO_REGS->Queue0_RXDMA_CP = (int )RX_DESCP0_0;
  }
 SRIO_REGS->DOORBELL0_ICCR=0xFFFFFFF;
 SRIO_REGS->DOORBELL1_ICCR=0xFFFFFFF;
 SRIO_REGS->DOORBELL2_ICCR=0xFFFFFFF;
 SRIO_REGS->DOORBELL3_ICCR=0xFFFFFFF;
 SRIO_REGS->INTDST0_Rate_CNTL=1;
```

, is

TEXAS NSTRUMENTS www.ti.com

# 5 SRIO Registers

# 5.1 Introduction

Table 40 lists the names and address offsets of the memory-mapped registers for the Serial RapidIO (SRIO) peripheral. See the device-specific data manual for the exact memory addresses of these registers.

| Offset | Acronym            | Register Description                              | Section      |
|--------|--------------------|---------------------------------------------------|--------------|
| 0000h  | PID                | Peripheral Identification Register                | Section 5.2  |
| 0004h  | PCR                | Peripheral Control Register                       | Section 5.3  |
| 0020h  | PER_SET_CNTL       | Peripheral Settings Control Register              | Section 5.4  |
| 0030h  | GBL_EN             | Peripheral Global Enable Register                 | Section 5.5  |
| 0034h  | GBL_EN_STAT        | Peripheral Global Enable Status                   | Section 5.6  |
| 0038h  | BLK0_EN            | Block Enable 0                                    | Section 5.7  |
| 003Ch  | BLK0_EN_STAT       | Block Enable Status 0                             | Section 5.8  |
| 0040h  | BLK1_EN            | Block Enable 1                                    | Section 5.7  |
| 0044h  | BLK1_EN_STAT       | Block Enable Status 1                             | Section 5.8  |
| 0048h  | BLK2_EN            | Block Enable 2                                    | Section 5.7  |
| 004Ch  | BLK2_EN_STAT       | Block Enable Status 2                             | Section 5.8  |
| 0050h  | BLK3_EN            | Block Enable 3                                    | Section 5.7  |
| 0054h  | BLK3_EN_STAT       | Block Enable Status 3                             | Section 5.8  |
| 0058h  | BLK4_EN            | Block Enable 4                                    | Section 5.7  |
| 005Ch  | BLK4_EN_STAT       | Block Enable Status 4                             | Section 5.8  |
| 0060h  | BLK5_EN            | Block Enable 5                                    | Section 5.7  |
| 0064h  | BLK5_EN_STAT       | Block Enable Status 5                             | Section 5.8  |
| 0068h  | BLK6_EN            | Block Enable 6                                    | Section 5.7  |
| 006Ch  | BLK6_EN_STAT       | Block Enable Status 6                             | Section 5.8  |
| 0070h  | BLK7_EN            | Block Enable 7                                    | Section 5.7  |
| 0074h  | BLK7_EN_STAT       | Block Enable Status 7                             | Section 5.8  |
| 0078h  | BLK8_EN            | Block Enable 8                                    | Section 5.7  |
| 007Ch  | BLK8_EN_STAT       | Block Enable Status 8                             | Section 5.8  |
| 0080h  | DEVICEID_REG1      | RapidIO DEVICEID1 Register                        | Section 5.9  |
| 0084h  | DEVICEID_REG2      | RapidIO DEVICEID2 Register                        | Section 5.10 |
| 0090h  | PF_16B_CNTL0       | Packet Forwarding Register 0 for 16-bit DeviceIDs | Section 5.11 |
| 0094h  | PF_8B_CNTL0        | Packet Forwarding Register 0 for 8-bit DeviceIDs  | Section 5.12 |
| 0098h  | PF_16B_CNTL1       | Packet Forwarding Register 1 for 16-bit DeviceIDs | Section 5.11 |
| 009Ch  | PF_8B_CNTL1        | Packet Forwarding Register 1 for 8-bit DeviceIDs  | Section 5.12 |
| 00A0h  | PF_16B_CNTL2       | Packet Forwarding Register 2 for 16-bit DeviceIDs | Section 5.11 |
| 00A4h  | PF_8B_CNTL2        | Packet Forwarding Register 2 for 8-bit DeviceIDs  | Section 5.12 |
| 00A8h  | PF_16B_CNTL3       | Packet Forwarding Register 3 for 16-bit DeviceIDs | Section 5.11 |
| 00ACh  | PF_8B_CNTL3        | Packet Forwarding Register 3 for 8-bit DeviceIDs  | Section 5.12 |
| 0100h  | SERDES_CFGRX0_CNTL | SERDES Receive Channel Configuration Register 0   | Section 5.13 |
| 0104h  | SERDES_CFGRX1_CNTL | SERDES Receive Channel Configuration Register 1   | Section 5.13 |
| 0108h  | SERDES_CFGRX2_CNTL | SERDES Receive Channel Configuration Register 2   | Section 5.13 |
| 010Ch  | SERDES_CFGRX3_CNTL | SERDES Receive Channel Configuration Register 3   | Section 5.13 |
| 0110h  | SERDES_CFGTX0_CNTL | SERDES Transmit Channel Configuration Register 0  | Section 5.14 |
| 0114h  | SERDES_CFGTX1_CNTL | SERDES Transmit Channel Configuration Register 1  | Section 5.14 |
| 0118h  | SERDES_CFGTX2_CNTL | SERDES Transmit Channel Configuration Register 2  | Section 5.14 |

# Table 40. Serial RapidIO (SRIO) Registers

| Offset | Acronym            | Register Description                                                      | Section      |
|--------|--------------------|---------------------------------------------------------------------------|--------------|
| 011Ch  | SERDES_CFGTX3_CNTL | SERDES Transmit Channel Configuration Register 3                          | Section 5.14 |
| 0120h  | SERDES_CFG0_CNTL   | SERDES Macro Configuration Register 0                                     | Section 5.15 |
| 0124h  | SERDES_CFG1_CNTL   | SERDES Macro Configuration Register 1                                     | Section 5.15 |
| 0128h  | SERDES_CFG2_CNTL   | SERDES Macro Configuration Register 2                                     | Section 5.15 |
| 012Ch  | SERDES_CFG3_CNTL   | SERDES Macro Configuration Register 3                                     | Section 5.15 |
| 0200h  | DOORBELL0_ICSR     | DOORBELL Interrupt Condition Status Register 0                            | Section 5.16 |
| 0208h  | DOORBELL0_ICCR     | DOORBELL Interrupt Condition Clear Register 0                             | Section 5.17 |
| 0210h  | DOORBELL1_ICSR     | DOORBELL Interrupt Condition Status Register 1                            | Section 5.16 |
| 0218h  | DOORBELL1_ICCR     | DOORBELL Interrupt Condition Clear Register 1                             | Section 5.17 |
| 0220h  | DOORBELL2_ICSR     | DOORBELL Interrupt Condition Status Register 2                            | Section 5.16 |
| 0228h  | DOORBELL2_ICCR     | DOORBELL Interrupt Condition Clear Register 2                             | Section 5.17 |
| 0230h  | DOORBELL3_ICSR     | DOORBELL Interrupt Condition Status Register 3                            | Section 5.16 |
| 0238h  | DOORBELL3_ICCR     | DOORBELL Interrupt Condition Clear Register 3                             | Section 5.17 |
| 0240h  | RX_CPPI_ICSR       | RX CPPI Interrupt Condition Status Register                               | Section 5.18 |
| 0248h  | RX_CPPI_ICCR       | RX CPPI Interrupt Condition Clear Register                                | Section 5.19 |
| 0250h  | TX_CPPI_ICSR       | TX CPPI Interrupt Condition Status Register                               | Section 5.20 |
| 0258h  | TX_CPPI_ICCR       | TX CPPI Interrupt Condition Clear Register                                | Section 5.21 |
| 0260h  | LSU_ICSR           | LSU Interrupt Condition Status Register                                   | Section 5.22 |
| 0268h  | LSU_ICCR           | LSU Interrupt Condition Clear Register                                    | Section 5.23 |
| 0270h  | ERR_RST_EVNT_ICSR  | Error, Reset, and Special Event Interrupt Condition Status Register       | Section 5.24 |
| 0278h  | ERR_RST_EVNT_ICCR  | Error, Reset, and Special Event Interrupt Condition Clear Register        | Section 5.25 |
| 0280h  | DOORBELL0_ICRR     | DOORBELL0 Interrupt Condition Routing Register                            | Section 5.26 |
| 0284h  | DOORBELL0_ICRR2    | DOORBELL 0 Interrupt Condition Routing Register 2                         | Section 5.26 |
| 0290h  | DOORBELL1_ICRR     | DOORBELL1 Interrupt Condition Routing Register                            | Section 5.26 |
| 0294h  | DOORBELL1_ICRR2    | DOORBELL 1 Interrupt Condition Routing Register 2                         | Section 5.26 |
| 02A0h  | DOORBELL2_ICRR     | DOORBELL2 Interrupt Condition Routing Register                            | Section 5.26 |
| 02A4h  | DOORBELL2_ICRR2    | DOORBELL 2 Interrupt Condition Routing Register 2                         | Section 5.26 |
| 02B0h  | DOORBELL3_ICRR     | DOORBELL3 Interrupt Condition Routing Register                            | Section 5.26 |
| 02B4h  | DOORBELL3_ICRR2    | DOORBELL 3 Interrupt Condition Routing Register 2                         | Section 5.26 |
| 02C0h  | RX_CPPI _ICRR      | Receive CPPI Interrupt Condition Routing Register                         | Section 5.27 |
| 02C4h  | RX_CPPI _ICRR2     | Receive CPPI Interrupt Condition Routing Register 2                       | Section 5.27 |
| 02D0h  | TX_CPPI _ICRR      | Transmit CPPI Interrupt Condition Routing Register                        | Section 5.28 |
| 02D4h  | TX_CPPI _ICRR2     | Transmit CPPI Interrupt Condition Routing Register 2                      | Section 5.28 |
| 02E0h  | LSU_ICRR0          | LSU Interrupt Condition Routing Register 0                                | Section 5.29 |
| 02E4h  | LSU_ICRR1          | LSU Interrupt Condition Routing Register 1                                | Section 5.29 |
| 02E8h  | LSU_ICRR2          | LSU Interrupt Condition Routing Register 2                                | Section 5.29 |
| 02ECh  | LSU_ICRR3          | LSU Interrupt Condition Routing Register 3                                | Section 5.29 |
| 02F0h  | ERR_RST_EVNT_ICRR  | Error, Reset, and Special Event Interrupt Condition Routing Register      | Section 5.30 |
| 02F4h  | ERR_RST_EVNT_ICRR2 | Error, Reset, and Special Event Interrupt Condition Routing Register 2    | Section 5.30 |
| 02F8h  | ERR_RST_EVNT_ICRR3 | Error, Reset, and Special Event Interrupt Condition Routing<br>Register 3 | Section 5.30 |
| 0300h  | INTDST0_DECODE     | INTDST Interrupt Status Decode Register 0                                 | Section 5.31 |
| 0304h  | INTDST1_DECODE     | INTDST Interrupt Status Decode Register 1                                 | Section 5.31 |
| 0308h  | INTDST2_DECODE     | INTDST Interrupt Status Decode Register 2                                 | Section 5.31 |



| Offset | Acronym           | Register Description                                  | Section       |
|--------|-------------------|-------------------------------------------------------|---------------|
| 030Ch  | INTDST3_DECODE    | INTDST Interrupt Status Decode Register 3             | Section 5.31  |
| 0310h  | INTDST4_DECODE    | INTDST Interrupt Status Decode Register 4             | Section 5.31  |
| 0314h  | INTDST5_DECODE    | INTDST Interrupt Status Decode Register 5             | Section 5.31  |
| 0318h  | INTDST6_DECODE    | INTDST Interrupt Status Decode Register 6             | Section 5.31  |
| 031Ch  | INTDST7_DECODE    | INTDST Interrupt Status Decode Register 7             | Section 5.31  |
| 0320h  | INTDST0_RATE_CNTL | INTDST Interrupt Rate Control Register 0              | Section 5.32  |
| 0324h  | INTDST1_RATE_CNTL | INTDST Interrupt Rate Control Register 1              | Section 5.32  |
| 0328h  | INTDST2_RATE_CNTL | INTDST Interrupt Rate Control Register 2              | Section 5.32  |
| 032Ch  | INTDST3_RATE_CNTL | INTDST Interrupt Rate Control Register 3              | Section 5.32  |
| 0330h  | INTDST4_RATE_CNTL | INTDST Interrupt Rate Control Register 4              | Section 5.32  |
| 0334h  | INTDST5_RATE_CNTL | INTDST Interrupt Rate Control Register 5              | Section 5.32  |
| 0338h  | INTDST6_RATE_CNTL | INTDST Interrupt Rate Control Register 6              | Section 5.32  |
| 033Ch  | INTDST7_RATE_CNTL | INTDST Interrupt Rate Control Register 7              | Section 5.32  |
| 0400h  | LSU1_REG0         | LSU1 Control Register 0                               | Section 5.33  |
| 0404h  | <br>LSU1_REG1     | LSU1 Control Register 1                               | Section 5.34  |
| 0408h  | LSU1_REG2         | LSU1 Control Register 2                               | Section 5.35  |
| 040Ch  | LSU1_REG3         | LSU1 Control Register 3                               | Section 5.36  |
| 0410h  | LSU1_REG4         | LSU1 Control Register 4                               | Section 5.37  |
| 0414h  | <br>LSU1_REG5     | LSU1 Control Register 5                               | Section 5.38  |
| 0418h  | LSU1_REG6         | LSU1 Control Register 6                               | Section 5.39  |
| 041Ch  | LSU1_FLOW_MASKS   | LSU1 Congestion Control Flow Mask Register            | Section 5.40  |
| 0420h  | LSU2_REG0         | LSU2 Control Register 0                               | Section 5.33  |
| 0424h  | <br>LSU2_REG1     | LSU2 Control Register 1                               | Section 5.34  |
| 0428h  | LSU2_REG2         | LSU2 Control Register 2                               | Section 5.35  |
| 042Ch  | LSU2_REG3         | LSU2 Control Register 3                               | Section 5.36  |
| 0430h  | LSU2_REG4         | LSU2 Control Register 4                               | Section 5.37  |
| 0434h  | LSU2_REG5         | LSU2 Control Register 5                               | Section 5.38  |
| 0438h  | <br>LSU2_REG6     | LSU2 Control Register 6                               | Section 5.39  |
| 043Ch  | LSU2_FLOW_MASKS1  | LSU2 Congestion Control Flow Mask Register            | Section 5.40  |
| 0440h  | LSU3_REG0         | LSU3 Control Register 0                               | Section 5.33  |
| 0444h  | LSU3_REG1         | LSU3 Control Register 1                               | Section 5.34  |
| 0448h  | LSU3_REG2         | LSU3 Control Register 2                               | Section 5.35  |
| 044Ch  | LSU3_REG3         | LSU3 Control Register 3                               | Section 5.36  |
| 0450h  | LSU3_REG4         | LSU3 Control Register 4                               | Section 5.37  |
| 0454h  | LSU3_REG5         | LSU3 Control Register 5                               | Section 5.38  |
| 0458h  | LSU3_REG6         | LSU3 Control Register 6                               | Section 5.39  |
| 045Ch  | LSU3_FLOW_MASKS2  | LSU3 Congestion Control Flow Mask Register            | Section 5.40  |
| 0460h  | LSU4_REG0         | LSU4 Control Register 0                               | Section 5.33  |
| 0464h  | LSU4_REG1         | LSU4 Control Register 1                               | Section 5.34  |
| 0468h  | LSU4_REG2         | LSU4 Control Register 2                               | Section 5.35  |
| 046Ch  | LSU4_REG3         | LSU4 Control Register 3                               | Section 5.36  |
| 0470h  | LSU4_REG4         | LSU4 Control Register 4                               | Section 5.37  |
| 0474h  | LSU4_REG5         | LSU4 Control Register 5                               | Section 5.38≈ |
| 0478h  | LSU4_REG6         | LSU4 Control Register 6                               | Section 5.39  |
| 0470h  | LSU4_FLOW_MASKS3  | LSU4 Congestion Control Flow Mask Register            | Section 5.40  |
| 0500h  | QUEUE0_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 0 | Section 5.41  |

| Offset | Acronym           | Register Description                                   | Section      |
|--------|-------------------|--------------------------------------------------------|--------------|
| 0504h  | QUEUE1_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 1  | Section 5.41 |
| 0508h  | QUEUE2_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 2  | Section 5.41 |
| 050Ch  | QUEUE3_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 3  | Section 5.41 |
| 0510h  | QUEUE4_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 4  | Section 5.41 |
| 0514h  | QUEUE5_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 5  | Section 5.41 |
| 0518h  | QUEUE6_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 6  | Section 5.41 |
| 051Ch  | QUEUE7_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 7  | Section 5.41 |
| 0520h  | QUEUE8_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 8  | Section 5.41 |
| 0524h  | QUEUE9_TXDMA_HDP  | Queue Transmit DMA Head Descriptor Pointer Register 9  | Section 5.41 |
| 0528h  | QUEUE10_TXDMA_HDP | Queue Transmit DMA Head Descriptor Pointer Register 10 | Section 5.41 |
| 052Ch  | QUEUE11_TXDMA_HDP | Queue Transmit DMA Head Descriptor Pointer Register 11 | Section 5.41 |
| 0530h  | QUEUE12_TXDMA_HDP | Queue Transmit DMA Head Descriptor Pointer Register 12 | Section 5.41 |
| 0534h  | QUEUE13_TXDMA_HDP | Queue Transmit DMA Head Descriptor Pointer Register 13 | Section 5.41 |
| 0538h  | QUEUE14_TXDMA_HDP | Queue Transmit DMA Head Descriptor Pointer Register 14 | Section 5.41 |
| 053Ch  | QUEUE15_TXDMA_HDP | Queue Transmit DMA Head Descriptor Pointer Register 15 | Section 5.41 |
| 0580h  | QUEUE0_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 0       | Section 5.42 |
| 0584h  | QUEUE1_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 1       | Section 5.42 |
| 0588h  | QUEUE2_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 2       | Section 5.42 |
| 058Ch  | QUEUE3_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 3       | Section 5.42 |
| 0590h  | QUEUE4_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 4       | Section 5.42 |
| 0594h  | QUEUE5_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 5       | Section 5.42 |
| 0598h  | QUEUE6_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 6       | Section 5.42 |
| 059Ch  | QUEUE7_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 7       | Section 5.42 |
| 05A0h  | QUEUE8_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 8       | Section 5.42 |
| 05A4h  | QUEUE9_TXDMA_CP   | Queue Transmit DMA Completion Pointer Register 9       | Section 5.42 |
| 05A8h  | QUEUE10_TXDMA_CP  | Queue Transmit DMA Completion Pointer Register 10      | Section 5.42 |
| 05ACh  | QUEUE11_TXDMA_CP  | Queue Transmit DMA Completion Pointer Register 11      | Section 5.42 |
| 05B0h  | QUEUE12_TXDMA_CP  | Queue Transmit DMA Completion Pointer Register 12      | Section 5.42 |
| 05B4h  | QUEUE13_TXDMA_CP  | Queue Transmit DMA Completion Pointer Register 13      | Section 5.42 |
| 05B8h  | QUEUE14_TXDMA_CP  | Queue Transmit DMA Completion Pointer Register 14      | Section 5.42 |
| 05BCh  | QUEUE15_TXDMA_CP  | Queue Transmit DMA Completion Pointer Register 15      | Section 5.42 |
| 0600h  | QUEUE0_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 0   | Section 5.43 |
| 0604h  | QUEUE1_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 1   | Section 5.43 |
| 0608h  | QUEUE2_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 2   | Section 5.43 |
| 060Ch  | QUEUE3_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 3   | Section 5.43 |
| 0610h  | QUEUE4_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 4   | Section 5.43 |
| 0614h  | QUEUE5_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 5   | Section 5.43 |
| 0618h  | QUEUE6_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 6   | Section 5.43 |
| 061Ch  | QUEUE7_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 7   | Section 5.43 |
| 0620h  | QUEUE8_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 8   | Section 5.43 |
| 0624h  | QUEUE9_RXDMA_HDP  | Queue Receive DMA Head Descriptor Pointer Register 9   | Section 5.43 |
| 0628h  | QUEUE10_RXDMA_HDP | Queue Receive DMA Head Descriptor Pointer Register 10  | Section 5.43 |
| 062Ch  | QUEUE11_RXDMA_HDP | Queue Receive DMA Head Descriptor Pointer Register 11  | Section 5.43 |
| 0630h  | QUEUE12_RXDMA_HDP | Queue Receive DMA Head Descriptor Pointer Register 12  | Section 5.43 |
| 0634h  | QUEUE13_RXDMA_HDP | Queue Receive DMA Head Descriptor Pointer Register 13  | Section 5.43 |
| 0638h  | QUEUE14_RXDMA_HDP | Queue Receive DMA Head Descriptor Pointer Register 14  | Section 5.43 |



| Offset | Acronym             | Register Description                                  | Section      |
|--------|---------------------|-------------------------------------------------------|--------------|
| 063Ch  | QUEUE15_RXDMA_HDP   | Queue Receive DMA Head Descriptor Pointer Register 15 | Section 5.43 |
| 0680h  | QUEUE0_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 0       | Section 5.44 |
| 0684h  | QUEUE1_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 1       | Section 5.44 |
| 0688h  | QUEUE2_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 2       | Section 5.44 |
| 068Ch  | QUEUE3_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 3       | Section 5.44 |
| 0690h  | QUEUE4_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 4       | Section 5.44 |
| 0694h  | QUEUE5_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 5       | Section 5.44 |
| 0698h  | QUEUE6_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 6       | Section 5.44 |
| 069Ch  | QUEUE7_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 7       | Section 5.44 |
| 06A0h  | QUEUE8_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 8       | Section 5.44 |
| 06A4h  | QUEUE9_RXDMA_CP     | Queue Receive DMA Completion Pointer Register 9       | Section 5.44 |
| 06A8h  | QUEUE10_RXDMA_CP    | Queue Receive DMA Completion Pointer Register 10      | Section 5.44 |
| 06ACh  | QUEUE11_RXDMA_CP    | Queue Receive DMA Completion Pointer Register 11      | Section 5.44 |
| 06B0h  | QUEUE12_RXDMA_CP    | Queue Receive DMA Completion Pointer Register 12      | Section 5.44 |
| 06B4h  | QUEUE13_RXDMA_CP    | Queue Receive DMA Completion Pointer Register 13      | Section 5.44 |
| 06B8h  | QUEUE14_RXDMA_CP    | Queue Receive DMA Completion Pointer Register 14      | Section 5.44 |
| 06BCh  | QUEUE15_RXDMA_CP    | Queue Receive DMA Completion Pointer Register 15      | Section 5.44 |
| 0700h  | TX_QUEUE_TEAR_DOWN  | Transmit Queue Teardown Register                      | Section 5.45 |
| 0704h  | TX_CPPI_FLOW_MASKS0 | Transmit CPPI Supported Flow Mask Register 0          | Section 5.46 |
| 0708h  | TX_CPPI_FLOW_MASKS1 | Transmit CPPI Supported Flow Mask Register 1          | Section 5.46 |
| 070Ch  | TX_CPPI_FLOW_MASKS2 | Transmit CPPI Supported Flow Mask Register 2          | Section 5.46 |
| 0710h  | TX_CPPI_FLOW_MASKS3 | Transmit CPPI Supported Flow Mask Register 3          | Section 5.46 |
| 0714h  | TX_CPPI_FLOW_MASKS4 | Transmit CPPI Supported Flow Mask Register 4          | Section 5.46 |
| 0718h  | TX_CPPI_FLOW_MASKS5 | Transmit CPPI Supported Flow Mask Register 5          | Section 5.46 |
| 071Ch  | TX_CPPI_FLOW_MASKS6 | Transmit CPPI Supported Flow Mask Register 6          | Section 5.46 |
| 0720h  | TX_CPPI_FLOW_MASKS7 | Transmit CPPI Supported Flow Mask Register 7          | Section 5.46 |
| 0740h  | RX_QUEUE_TEAR_DOWN  | Receive Queue Teardown Register                       | Section 5.47 |
| 0744h  | RX_CPPI_CNTL        | Receive CPPI Control Register                         | Section 5.48 |
| 07E0h  | TX_QUEUE_CNTL0      | Transmit CPPI Weighted Round Robin Control Register 0 | Section 5.49 |
| 07E4h  | TX_QUEUE_CNTL1      | Transmit CPPI Weighted Round Robin Control Register 1 | Section 5.49 |
| 07E8h  | TX_QUEUE_CNTL2      | Transmit CPPI Weighted Round Robin Control Register 2 | Section 5.49 |
| 07ECh  | TX_QUEUE_CNTL3      | Transmit CPPI Weighted Round Robin Control Register 3 | Section 5.49 |
| 0800h  | RXU_MAP_L0          | MailBox-to-Queue Mapping Register L0                  | Section 5.50 |
| 0804h  | RXU_MAP_H0          | MailBox-to-Queue Mapping Register H0                  | Section 5.50 |
| 0808h  | RXU_MAP_L1          | MailBox-to-Queue Mapping Register L1                  | Section 5.50 |
| 080Ch  | RXU_MAP_H1          | MailBox-to-Queue Mapping Register H1                  | Section 5.50 |
| 0810h  | RXU_MAP_L2          | MailBox-to-Queue Mapping Register L2                  | Section 5.50 |
| 0814h  | RXU_MAP_H2          | MailBox-to-Queue Mapping Register H2                  | Section 5.50 |
| 0818h  | RXU_MAP_L3          | MailBox-to-Queue Mapping Register L3                  | Section 5.50 |
| 081Ch  | RXU_MAP_H3          | MailBox-to-Queue Mapping Register H3                  | Section 5.50 |
| 0820h  | RXU_MAP_L4          | MailBox-to-Queue Mapping Register L4                  | Section 5.50 |
| 0824h  | RXU_MAP_H4          | MailBox-to-Queue Mapping Register H4                  | Section 5.50 |
| 0828h  | RXU_MAP_L5          | MailBox-to-Queue Mapping Register L5                  | Section 5.50 |
| 082Ch  | RXU_MAP_H5          | MailBox-to-Queue Mapping Register H5                  | Section 5.50 |
| 0830h  | RXU_MAP_L6          | MailBox-to-Queue Mapping Register L6                  | Section 5.50 |
| 0834h  | RXU_MAP_H6          | MailBox-to-Queue Mapping Register H6                  | Section 5.50 |

| Offset | Acronym     | Register Description                  | Section      |
|--------|-------------|---------------------------------------|--------------|
| 0838h  | RXU_MAP_L7  | MailBox-to-Queue Mapping Register L7  | Section 5.50 |
| 083Ch  | RXU_MAP_H7  | MailBox-to-Queue Mapping Register H7  | Section 5.50 |
| 0840h  | RXU_MAP_L8  | MailBox-to-Queue Mapping Register L8  | Section 5.50 |
| 0844h  | RXU_MAP_H8  | MailBox-to-Queue Mapping Register H8  | Section 5.50 |
| 0848h  | RXU_MAP_L9  | MailBox-to-Queue Mapping Register L9  | Section 5.50 |
| 084Ch  | RXU_MAP_H9  | MailBox-to-Queue Mapping Register H9  | Section 5.50 |
| 0850h  | RXU_MAP_L10 | MailBox-to-Queue Mapping Register L10 | Section 5.50 |
| 0854h  | RXU_MAP_H10 | MailBox-to-Queue Mapping Register H10 | Section 5.50 |
| 0858h  | RXU_MAP_L11 | MailBox-to-Queue Mapping Register L11 | Section 5.50 |
| 085Ch  | RXU_MAP_H11 | MailBox-to-Queue Mapping Register H11 | Section 5.50 |
| 0860h  | RXU_MAP_L12 | MailBox-to-Queue Mapping Register L12 | Section 5.50 |
| 0864h  | RXU_MAP_H12 | MailBox-to-Queue Mapping Register H12 | Section 5.50 |
| 0868h  | RXU_MAP_L13 | MailBox-to-Queue Mapping Register L13 | Section 5.50 |
| 086Ch  | RXU_MAP_H13 | MailBox-to-Queue Mapping Register H13 | Section 5.50 |
| 0870h  | RXU_MAP_L14 | MailBox-to-Queue Mapping Register L14 | Section 5.50 |
| 0874h  | RXU_MAP_H14 | MailBox-to-Queue Mapping Register H14 | Section 5.50 |
| 0878h  | RXU_MAP_L15 | MailBox-to-Queue Mapping Register L15 | Section 5.50 |
| 087Ch  | RXU_MAP_H15 | MailBox-to-Queue Mapping Register H15 | Section 5.50 |
| 0880h  | RXU_MAP_L16 | MailBox-to-Queue Mapping Register L16 | Section 5.50 |
| 0884h  | RXU_MAP_H16 | MailBox-to-Queue Mapping Register H16 | Section 5.50 |
| 0888h  | RXU_MAP_L17 | MailBox-to-Queue Mapping Register L17 | Section 5.50 |
| 088Ch  | RXU_MAP_H17 | MailBox-to-Queue Mapping Register H17 | Section 5.50 |
| 0890h  | RXU_MAP_L18 | MailBox-to-Queue Mapping Register L18 | Section 5.50 |
| 0894h  | RXU_MAP_H18 | MailBox-to-Queue Mapping Register H18 | Section 5.50 |
| 0898h  | RXU_MAP_L19 | MailBox-to-Queue Mapping Register L19 | Section 5.50 |
| 089Ch  | RXU_MAP_H19 | MailBox-to-Queue Mapping Register H19 | Section 5.50 |
| 08A0h  | RXU_MAP_L20 | MailBox-to-Queue Mapping Register L20 | Section 5.50 |
| 08A4h  | RXU_MAP_H20 | MailBox-to-Queue Mapping Register H20 | Section 5.50 |
| 08A8h  | RXU_MAP_L21 | MailBox-to-Queue Mapping Register L21 | Section 5.50 |
| 08ACh  | RXU_MAP_H21 | MailBox-to-Queue Mapping Register H21 | Section 5.50 |
| 08B0h  | RXU_MAP_L22 | MailBox-to-Queue Mapping Register L22 | Section 5.50 |
| 08B4h  | RXU_MAP_H22 | MailBox-to-Queue Mapping Register H22 | Section 5.50 |
| 08B8h  | RXU_MAP_L23 | MailBox-to-Queue Mapping Register L23 | Section 5.50 |
| 08BCh  | RXU_MAP_H23 | MailBox-to-Queue Mapping Register H23 | Section 5.50 |
| 08C0h  | RXU_MAP_L24 | MailBox-to-Queue Mapping Register L24 | Section 5.50 |
| 08C4h  | RXU_MAP_H24 | MailBox-to-Queue Mapping Register H24 | Section 5.50 |
| 08C8h  | RXU_MAP_L25 | MailBox-to-Queue Mapping Register L25 | Section 5.50 |
| 08CCh  | RXU_MAP_H25 | MailBox-to-Queue Mapping Register H25 | Section 5.50 |
| 08D0h  | RXU_MAP_L26 | MailBox-to-Queue Mapping Register L26 | Section 5.50 |
| 08D4h  | RXU_MAP_H26 | MailBox-to-Queue Mapping Register H26 | Section 5.50 |
| 08D8h  | RXU_MAP_L27 | MailBox-to-Queue Mapping Register L27 | Section 5.50 |
| 08DCh  | RXU_MAP_H27 | MailBox-to-Queue Mapping Register H27 | Section 5.50 |
| 08E0h  | RXU_MAP_L28 | MailBox-to-Queue Mapping Register L28 | Section 5.50 |
| 08E4h  | RXU_MAP_H28 | MailBox-to-Queue Mapping Register H28 | Section 5.50 |
| 08E8h  | RXU_MAP_L29 | MailBox-to-Queue Mapping Register L29 | Section 5.50 |
| 08ECh  | RXU_MAP_H29 | MailBox-to-Queue Mapping Register H29 | Section 5.50 |



| Offset | Acronym           | Register Description                          | Section      |
|--------|-------------------|-----------------------------------------------|--------------|
| 08F0h  | RXU_MAP_L30       | MailBox-to-Queue Mapping Register L30         | Section 5.50 |
| 08F4h  | RXU_MAP_H30       | MailBox-to-Queue Mapping Register H30         | Section 5.50 |
| 08F8h  | RXU_MAP_L31       | MailBox-to-Queue Mapping Register L31         | Section 5.50 |
| 08FCh  | RXU_MAP_H31       | MailBox-to-Queue Mapping Register H31         | Section 5.50 |
| 0900h  | FLOW_CNTL0        | Flow Control Table Entry Register 0           | Section 5.51 |
| 0904h  | FLOW_CNTL1        | Flow Control Table Entry Register 1           | Section 5.51 |
| 0908h  | FLOW_CNTL2        | Flow Control Table Entry Register 2           | Section 5.51 |
| 090Ch  | FLOW CNTL3        | Flow Control Table Entry Register 3           | Section 5.51 |
| 0910h  | FLOW_CNTL4        | Flow Control Table Entry Register 4           | Section 5.51 |
| 0914h  | FLOW_CNTL5        | Flow Control Table Entry Register 5           | Section 5.51 |
| 0918h  | FLOW_CNTL6        | Flow Control Table Entry Register 6           | Section 5.51 |
| 091Ch  | FLOW_CNTL7        | Flow Control Table Entry Register 7           | Section 5.51 |
| 0920h  | FLOW_CNTL8        | Flow Control Table Entry Register 8           | Section 5.51 |
| 0924h  | FLOW_CNTL9        | Flow Control Table Entry Register 9           | Section 5.51 |
| 0928h  | FLOW_CNTL10       | Flow Control Table Entry Register 10          | Section 5.51 |
| 092Ch  | FLOW_CNTL11       | Flow Control Table Entry Register 11          | Section 5.51 |
| 0930h  | FLOW_CNTL12       | Flow Control Table Entry Register 12          | Section 5.51 |
| 0934h  | FLOW_CNTL13       | Flow Control Table Entry Register 13          | Section 5.51 |
| 0938h  | FLOW_CNTL14       | Flow Control Table Entry Register 14          | Section 5.51 |
| 093Ch  | FLOW_CNTL15       | Flow Control Table Entry Register 15          | Section 5.51 |
| 1000h  | <br>DEV_ID        | Device Identity CAR                           | Section 5.52 |
| 1004h  | <br>DEV_INFO      | Device Information CAR                        | Section 5.53 |
| 1008h  | ASBLY_ID          | Assembly Identity CAR                         | Section 5.54 |
| 100Ch  | ASBLY_INFO        | Assembly Information CAR                      | Section 5.55 |
| 1010h  | PE_FEAT           | Processing Element Features CAR               | Section 5.56 |
| 1018h  | SRC_OP            | Source Operations CAR                         | Section 5.57 |
| 101Ch  | DEST_OP           | Destination Operations CAR                    | Section 5.58 |
| 104Ch  | PE_LL_CTL         | Processing Element Logical Layer Control CSR  | Section 5.59 |
| 1058h  | LCL_CFG_HBAR      | Local Configuration Space Base Address 0 CSR  | Section 5.60 |
| 105Ch  | LCL_CFG_BAR       | Local Configuration Space Base Address 1 CSR  | Section 5.61 |
| 1060h  | BASE_ID           | Base Device ID CSR                            | Section 5.62 |
| 1068h  | HOST_BASE_ID_LOCK | Host Base Device ID Lock CSR                  | Section 5.63 |
| 106Ch  | COMP_TAG          | Component Tag CSR                             | Section 5.64 |
| 1100h  | SP_MB_HEAD        | 1x/4x LP_Serial Port Maintenance Block Header | Section 5.65 |
| 1120h  | SP_LT_CTL         | Port Link Time-Out Control CSR                | Section 5.66 |
| 1124h  | SP_RT_CTL         | Port Response Time-Out Control CSR            | Section 5.67 |
| 113Ch  | SP_GEN_CTL        | Port General Control CSR                      | Section 5.68 |
| 1140h  | SP0_LM_REQ        | Port 0 Link Maintenance Request CSR           | Section 5.69 |
| 1144h  | SP0_LM_RESP       | Port 0 Link Maintenance Response CSR          | Section 5.70 |
| 1148h  | SP0_ACKID_STAT    | Port 0 Local AckID Status CSR                 | Section 5.71 |
| 1158h  | SP0_ERR_STAT      | Port 0 Error and Status CSR                   | Section 5.72 |
| 115Ch  | SP0_CTL           | Port 0 Control CSR                            | Section 5.73 |
| 1160h  | SP1_LM_REQ        | Port 1 Link Maintenance Request CSR           | Section 5.69 |
| 1164h  | SP1_LM_RESP       | Port 1 Link Maintenance Response CSR          | Section 5.70 |
| 1168h  | SP1_ACKID_STAT    | Port 1 Local AckID Status CSR                 | Section 5.71 |
| 1178h  | SP1_ERR_STAT      | Port 1 Error and Status CSR                   | Section 5.72 |
|        |                   |                                               |              |

| Offset | Acronym                | Register Description                             | Section      |
|--------|------------------------|--------------------------------------------------|--------------|
| 117Ch  | SP1_CTL                | Port 1 Control CSR                               | Section 5.73 |
| 1180h  | SP2_LM_REQ             | Port 2 Link Maintenance Request CSR              | Section 5.69 |
| 1184h  | SP2_LM_RESP            | Port 2 Link Maintenance Response CSR             | Section 5.70 |
| 1188h  | SP2_ACKID_STAT         | Port 2 Local AckID Status CSR                    | Section 5.71 |
| 1198h  | SP2_ERR_STAT           | Port 2 Error and Status CSR                      | Section 5.72 |
| 119Ch  | SP2_CTL                | Port 2 Control CSR                               | Section 5.73 |
| 11A0h  | SP3_LM_REQ             | Port 3 Link Maintenance Request CSR              | Section 5.69 |
| 11A4h  | SP3_LM_RESP            | Port 3 Link Maintenance Response CSR             | Section 5.70 |
| 11A8h  | SP3_ACKID_STAT         | Port 3 Local AckID Status CSR                    | Section 5.71 |
| 11B8h  | SP3_ERR_STAT           | Port 3 Error and Status CSR                      | Section 5.72 |
| 11BCh  | SP3_CTL                | Port 3 Control CSR                               | Section 5.73 |
| 2000h  | ERR_RPT_BH             | Error Reporting Block Header                     | Section 5.74 |
| 2008h  | ERR_DET                | Logical/Transport Layer Error Detect CSR         | Section 5.75 |
| 200Ch  | ERR_EN                 | Logical/Transport Layer Error Enable CSR         | Section 5.76 |
| 2010h  | H_ADDR_CAPT            | Logical/Transport Layer High Address Capture CSR | Section 5.77 |
| 2014h  | ADDR_CAPT              | Logical/Transport Layer Address Capture CSR      | Section 5.78 |
| 2018h  | ID_CAPT                | Logical/Transport Layer Device ID Capture CSR    | Section 5.79 |
| 201Ch  | CTRL_CAPT              | Logical/Transport Layer Control Capture CSR      | Section 5.80 |
| 2028h  | PW_TGT_ID              | Port-Write Target Device ID CSR                  | Section 5.81 |
| 2040h  | SP0_ERR_DET            | Port 0 Error Detect CSR                          | Section 5.82 |
| 2044h  | SP0_RATE_EN            | Port 0 Error Enable CSR                          | Section 5.83 |
| 2048h  | SP0_ERR_ATTR_CAPT_DBG0 | Port 0 Attributes Error Capture CSR 0            | Section 5.84 |
| 204Ch  | SP0_ERR_CAPT_DBG1      | Port 0 Packet/Control Symbol Error Capture CSR 1 | Section 5.85 |
| 2050h  | SP0_ERR_CAPT_DBG2      | Port 0 Packet/Control Symbol Error Capture CSR 2 | Section 5.86 |
| 2054h  | SP0_ERR_CAPT_DBG3      | Port 0 Packet/Control Symbol Error Capture CSR 3 | Section 5.87 |
| 2058h  | SP0_ERR_CAPT_DBG4      | Port 0 Packet/Control Symbol Error Capture CSR 4 | Section 5.88 |
| 2068h  | SP0_ERR_RATE           | Port 0 Error Rate CSR 0                          | Section 5.89 |
| 206Ch  | SP0_ERR_THRESH         | Port 0 Error Rate Threshold CSR                  | Section 5.90 |
| 2080h  | SP1_ERR_DET            | Port 1 Error Detect CSR                          | Section 5.82 |
| 2084h  | SP1_RATE_EN            | Port 1 Error Enable CSR                          | Section 5.83 |
| 2088h  | SP1_ERR_ATTR_CAPT_DBG0 | Port 1 Attributes Error Capture CSR 0            | Section 5.84 |
| 208Ch  | SP1_ERR_CAPT_DBG1      | Port 1 Packet/Control Symbol Error Capture CSR 1 | Section 5.85 |
| 2090h  | SP1_ERR_CAPT_DBG2      | Port 1 Packet/Control Symbol Error Capture CSR 2 | Section 5.86 |
| 2094h  | SP1_ERR_CAPT_DBG3      | Port 1 Packet/Control Symbol Error Capture CSR 3 | Section 5.87 |
| 2098h  | SP1_ERR_CAPT_DBG4      | Port 1 Packet/Control Symbol Error Capture CSR 4 | Section 5.88 |
| 20A8h  | SP1_ERR_RATE           | Port 1 Error Rate CSR                            | Section 5.89 |
| 20ACh  | SP1_ERR_THRESH         | Port 1 Error Rate Threshold CSR                  | Section 5.90 |
| 20C0h  | SP2_ERR_DET            | Port 2 Error Detect CSR                          | Section 5.82 |
| 20C4h  | SP2_RATE_EN            | Port 2 Error Enable CSR                          | Section 5.83 |
| 20C8h  | SP2_ERR_ATTR_CAPT_DBG0 | Port 2 Attributes Error Capture CSR 0            | Section 5.84 |
| 20CCh  | SP2_ERR_CAPT_DBG1      | Port 2 Packet/Control Symbol Error Capture CSR 1 | Section 5.85 |
| 20D0h  | SP2_ERR_CAPT_DBG2      | Port 2 Packet/Control Symbol Error Capture CSR 2 | Section 5.86 |
| 20D4h  | SP2_ERR_CAPT_DBG3      | Port 2 Packet/Control Symbol Error Capture CSR 3 | Section 5.87 |
| 20D8h  | SP2_ERR_CAPT_DBG4      | Port 2 Packet/Control Symbol Error Capture CSR 4 | Section 5.88 |
| 20E8h  | SP2_ERR_RATE           | Port 2 Error Rate CSR                            | Section 5.89 |
| 20ECh  | SP2_ERR_THRESH         | Port 2 Error Rate Threshold CSR                  | Section 5.90 |

## Table 40. Serial RapidIO (SRIO) Registers (continued)



| Offset | Acronym                | Register Description                                   | Section      |
|--------|------------------------|--------------------------------------------------------|--------------|
| 2100h  | SP3_ERR_DET            | Port 3 Error Detect CSR                                | Section 5.82 |
| 2104h  | SP3_RATE_EN            | Port 3 Error Enable CSR                                | Section 5.83 |
| 2108h  | SP3_ERR_ATTR_CAPT_DBG0 | Port 3 Attributes Error Capture CSR 0                  | Section 5.84 |
| 210Ch  | SP3_ERR_CAPT_DBG1      | Port 3 Packet/Control Symbol Error Capture CSR 1       | Section 5.85 |
| 2110h  | SP3_ERR_CAPT_DBG2      | Port 3 Packet/Control Symbol Error Capture CSR 2       | Section 5.86 |
| 2114h  | SP3_ERR_CAPT_DBG3      | Port 3 Packet/Control Symbol Error Capture CSR 3       | Section 5.87 |
| 2118h  | SP3_ERR_CAPT_DBG4      | Port 3 Packet/Control Symbol Error Capture CSR 4       | Section 5.88 |
| 2128h  | SP3_ERR_RATE           | Port 3 Error Rate CSR                                  | Section 5.89 |
| 212Ch  | SP3_ERR_THRESH         | Port 3 Error Rate Threshold CSR                        | Section 5.90 |
| 12000h | SP_IP_DISCOVERY_TIMER  | Port IP Discovery Timer in 4x mode                     | Section 5.91 |
| 12004h | SP_IP_MODE             | Port IP Mode CSR                                       | Section 5.92 |
| 12008h | IP_PRESCAL             | Port IP Prescaler Register                             | Section 5.93 |
| 12010h | SP_IP_PW_IN_CAPT0      | Port-Write-In Capture CSR Register 0                   | Section 5.94 |
| 12014h | SP_IP_PW_IN_CAPT1      | Port-Write-In Capture CSR Register 1                   | Section 5.94 |
| 12018h | SP_IP_PW_IN_CAPT2      | Port-Write-In Capture CSR Register 2                   | Section 5.94 |
| 1201Ch | SP_IP_PW_IN_CAPT3      | Port-Write-In Capture CSR Register 3                   | Section 5.94 |
| 14000h | SP0_RST_OPT            | Port 0 Reset Option CSR                                | Section 5.95 |
| 14004h | SP0_CTL_INDEP          | Port 0 Control Independent Register                    | Section 5.96 |
| 14008h | SP0_SILENCE_TIMER      | Port 0 Silence Timer Register                          | Section 5.97 |
| 1400Ch | SP0_MULT_EVNT_CS       | Port 0 Multicast-Event Control Symbol Request Register | Section 5.98 |
| 14014h | SP0_CS_TX              | Port 0 Control Symbol Transmit Register                | Section 5.99 |
| 14100h | SP1_RST_OPT            | Port 1 Reset Option CSR                                | Section 5.95 |
| 14104h | SP1_CTL_INDEP          | Port 1 Control Independent Register                    | Section 5.96 |
| 14108h | SP1_SILENCE_TIMER      | Port 1 Silence Timer Register                          | Section 5.97 |
| 1410Ch | SP1_MULT_EVNT_CS       | Port 1 Multicast-Event Control Symbol Request Register | Section 5.98 |
| 14114h | SP1_CS_TX              | Port 1 Control Symbol Transmit Register                | Section 5.99 |
| 14200h | SP2_RST_OPT            | Port 2 Reset Option CSR                                | Section 5.95 |
| 14204h | SP2_CTL_INDEP          | Port 2 Control Independent Register                    | Section 5.96 |
| 14208h | SP2_SILENCE_TIMER      | Port 2 Silence Timer Register                          | Section 5.97 |
| 1420Ch | SP2_MULT_EVNT_CS       | Port 2 Multicast-Event Control Symbol Request Register | Section 5.98 |
| 14214h | SP2_CS_TX              | Port 2 Control Symbol Transmit Register                | Section 5.99 |
| 14300h | SP3_RST_OPT            | Port 3 Reset Option CSR                                | Section 5.95 |
| 14304h | SP3_CTL_INDEP          | Port 3 Control Independent Register                    | Section 5.96 |
| 14308h | SP3_SILENCE_TIMER      | Port 3 Silence Timer Register                          | Section 5.97 |
| 1430Ch | SP3_MULT_EVNT_CS       | Port 3 Multicast-Event Control Symbol Request Register | Section 5.98 |
| 14314h | SP3_CS_TX              | Port 3 Control Symbol Transmit Register                | Section 5.99 |

## Table 40. Serial RapidIO (SRIO) Registers (continued)

## 5.2 Peripheral Identification Register (PID)

The peripheral identification register (PID) is a read-only register that contains the ID and ID revision number for that peripheral. The PID stores version information used to identify the peripheral. Writes have no effect to this register. The values are hard coded and will not change from their reset state.

The peripheral ID register (PID) is shown in Figure 63 and described in Table 41.

## Figure 63. Peripheral ID Register (PID) - Address Offset 0000h

| 31 |          | 24 23 |       | 16 |
|----|----------|-------|-------|----|
|    | Reserved |       | TYPE  |    |
|    | R-00h    |       | R-01h |    |
| 15 |          | 8 7   |       | 0  |
|    | CLASS    |       | REV   |    |
|    | R-0Ah    |       | R-01h |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 41. Peripheral ID Register (PID) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                         |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24 | Reserved |       | Reserved                                                                                                                                            |
| 23–16 | TYPE     |       | Peripheral type: Identifies the type of the peripheral RIO                                                                                          |
| 15–8  | CLASS    |       | Peripheral class: Identifies the class Switch Fabric                                                                                                |
| 7–0   | REV      |       | Peripheral revision: Identifies the revision of the peripheral. This value should begin at 01h and be incremented each time the design is revised . |

## 5.3 Peripheral Control Register (PCR)

The peripheral control register (PCR) contains a bit that enables or disables data flow in the logical layer of the entire peripheral. In addition, the PCR has emulation control bits that control the peripheral behavior during emulation halts. PCR is shown in Figure 64 and described in Table 42. For additional programming information, see Section 2.3.11.

## Figure 64. Peripheral Control Register (PCR) - Address Offset 0004h

| 31 |          |   |       |       | 16    |
|----|----------|---|-------|-------|-------|
|    | Reserved |   |       |       |       |
|    | R-0      |   |       |       |       |
| 15 |          | 3 | 2     | 1     | 0     |
|    | Reserved |   | PEREN | SOFT  | FREE  |
|    | R-0      |   | R/W-0 | R/W-0 | R/W-1 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

## Table 42. Peripheral Control Register (PCR) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                                                                                                                 |  |  |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31–3 | Reserved | 0     | hese read-only bits return 0s when read.                                                                                                                                                                                                                                                                                    |  |  |
| 2    | PEREN    |       | Peripheral flow control enable. Controls the flow of data in the logical layer of the peripheral. As an initiator, it will prevent TX transaction generation; as a target, it will disable incoming requests. This should be the last enable bit to toggle when bringing the device out of reset to begin normal operation. |  |  |
|      |          | 0     | Data flow control is disabled.                                                                                                                                                                                                                                                                                              |  |  |
|      |          | 1     | Data flow control is enabled.                                                                                                                                                                                                                                                                                               |  |  |
| 1    | SOFT     |       | Soft stop. This bit and the FREE bit determine how the SRIO peripheral behaves during emulation halts.                                                                                                                                                                                                                      |  |  |
|      |          | 0     | Hard stop. All status registers are frozen in default state. (This mode is not supported on the SRIO peripheral.)                                                                                                                                                                                                           |  |  |
|      |          | 1     | Soft stop                                                                                                                                                                                                                                                                                                                   |  |  |
| 0    | FREE     |       | Free run                                                                                                                                                                                                                                                                                                                    |  |  |
|      |          | 0     | The SOFT bit takes effect.                                                                                                                                                                                                                                                                                                  |  |  |
|      |          | 1     | Free run. Peripheral ignores the emulation suspend signal and functions normally.                                                                                                                                                                                                                                           |  |  |

## 5.4 Peripheral Settings Control Register (PER\_SET\_CNTL)

The peripheral settings control register (PER\_SET\_CNTL) is shown in Figure 65 and described in Table 43. For additional programming information, see Section 2.3.12.

## Figure 65. Peripheral Settings Control Register (PER\_SET\_CNTL) (Address Offset 0020h)

| 31         |                  |    | 27        | 26                        | 25       | 24                |
|------------|------------------|----|-----------|---------------------------|----------|-------------------|
|            | Reserved         |    |           | SW_MEM_SLEEP_<br>OVERRIDE | LOOPBACK | BOOT_<br>COMPLETE |
|            | R-0              |    |           | R/W-1                     | R/W-0    | R/W-0             |
| 23         | 21               | 20 |           | 18                        | 17       | 16                |
|            | Reserved         |    | TX_PRI2_V | ٧M                        | TX_PR    | 1_WM              |
|            | R-0              |    | R/W-01h   | ı                         | R/W-     | -02h              |
| 15         | 14               | 12 | 11        |                           | 9        | 8                 |
| TX_PRI1_WM | TX_PRI0_WM       |    |           | CBA_TRANS_PRI             |          | 1X_MODE           |
| R/W-02h    | R/W-02h R/W-03h  |    |           | R/W-0                     |          | R/W-0             |
| 7 4        |                  |    | 3         | 2                         | 1        | 0                 |
|            | PRESCALER_SELECT |    |           | ENPLL3                    | ENPLL2   | ENPLL1            |
|            | R/W-0            |    |           | R/W-0                     | R/W-0    | R/W-0             |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 43. Peripheral Settings Control Register (PER\_SET\_CNTL) Field Descriptions

| Bit   | Field                 | Value     | Description                                                                                                                                                                                                                                                 |
|-------|-----------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–27 | Reserved              | 00000b    | These read-only bits return 0s when read.                                                                                                                                                                                                                   |
| 26    | SW_MEM_SLEEP_OVERRIDE |           | Software memory sleep override                                                                                                                                                                                                                              |
|       |                       | 0         | Memories are put in sleep mode while in shutdown                                                                                                                                                                                                            |
|       |                       | 1         | Memories are not put in sleep mode while in shutdown                                                                                                                                                                                                        |
| 25    | LOOPBACK              |           | Loopback mode                                                                                                                                                                                                                                               |
|       |                       | 0         | Normal operation                                                                                                                                                                                                                                            |
|       |                       | 1         | Loop back mode. Transmit data to receive on the same port. Packet data is looped back in the digital domain before the SERDES macros.                                                                                                                       |
| 24    | BOOT_COMPLETE         |           | Controls ability to write any register during initialization. It also includes read only registers during normal mode of operation that have application defined reset value.                                                                               |
|       |                       | 0         | Write to read-only registers enabled                                                                                                                                                                                                                        |
|       |                       | 1         | Write to read-only registers disabled. Usually the boot_complete is asserted once after reset to define power on configuration.                                                                                                                             |
| 23–21 | Reserved              | 000b      | These read-only bits return 0s when read.                                                                                                                                                                                                                   |
| 20–18 | TX_PRI2_WM            | 000b–111b | Transmit credit threshold. Sets the required number of logical layer TX buffers needed to send priority 2 packets across the UDI. This is valid for all ports in 1x mode only.<br>Required buffer count for transmit credit threshold 2 value (TX_PRI2_WM): |
|       |                       |           | • 000→8, 7, 6, 5, 4, 3, 2, 1 (effectively lets all of this priority pass)                                                                                                                                                                                   |
|       |                       |           | <ul> <li>001→8, 7, 6, 5, 4, 3, 2</li> </ul>                                                                                                                                                                                                                 |
|       |                       |           | <ul> <li>010→8, 7, 6, 5, 4, 3</li> </ul>                                                                                                                                                                                                                    |
|       |                       |           | <ul> <li>011→8, 7, 6, 5, 4</li> </ul>                                                                                                                                                                                                                       |
|       |                       |           | • 100→8, 7, 6, 5                                                                                                                                                                                                                                            |
|       |                       |           | • 101→8, 7, 6                                                                                                                                                                                                                                               |
|       |                       |           | • 110→8, 7                                                                                                                                                                                                                                                  |
|       |                       |           | <ul> <li>111→8</li> </ul>                                                                                                                                                                                                                                   |

## Table 43. Peripheral Settings Control Register (PER\_SET\_CNTL) Field Descriptions (continued)

| Bit   | Field            | Value          | Description                                                                                                                                                                                                                                                 |
|-------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17–15 | TX_PRI1_WM       | 000b–111b      | Transmit credit threshold. Sets the required number of logical layer TX buffers needed to send priority 1 packets across the UDI. This is valid for all ports in 1x mode only.<br>Required buffer count for transmit credit threshold 1 value (TX_PRI1_WM): |
|       |                  |                | <ul> <li>000→8, 7, 6, 5, 4, 3, 2, 1 (effectively lets all of this priority pass)</li> <li>001→8, 7, 6, 5, 4, 3, 2</li> </ul>                                                                                                                                |
|       |                  |                | <ul> <li>010→8, 7, 6, 5, 4, 3</li> </ul>                                                                                                                                                                                                                    |
|       |                  |                | • 011→8, 7, 6, 5, 4                                                                                                                                                                                                                                         |
|       |                  |                | <ul> <li>100→8, 7, 6, 5</li> <li>101→8, 7, 6</li> </ul>                                                                                                                                                                                                     |
|       |                  |                | <ul> <li>110→8, 7</li> </ul>                                                                                                                                                                                                                                |
|       |                  |                | <ul> <li>111→8</li> </ul>                                                                                                                                                                                                                                   |
| 14–12 | TX_PRI0_WM       | 000b–111b      | Transmit credit threshold. Sets the required number of logical layer TX buffers needed to send priority 0 packets across the UDI. This is valid for all ports in 1x mode only.<br>Required buffer count for transmit credit threshold 0 value (TX_PRI0_WM): |
|       |                  |                | • $000 \rightarrow 8, 7, 6, 5, 4, 3, 2, 1$ (effectively lets all of this priority pass)                                                                                                                                                                     |
|       |                  |                | <ul> <li>001→8, 7, 6, 5, 4, 3, 2</li> </ul>                                                                                                                                                                                                                 |
|       |                  |                | • 010→8, 7, 6, 5, 4, 3                                                                                                                                                                                                                                      |
|       |                  |                | <ul> <li>011→8, 7, 6, 5, 4</li> <li>100→8, 7, 6, 5</li> </ul>                                                                                                                                                                                               |
|       |                  |                | <ul> <li>101→8, 7, 6</li> </ul>                                                                                                                                                                                                                             |
|       |                  |                | <ul> <li>110→8, 7</li> </ul>                                                                                                                                                                                                                                |
|       |                  |                | • 111->8                                                                                                                                                                                                                                                    |
| 11–9  | CBA_TRANS_PRI    | 000b–111b      | DSP system transaction priority. 000b – Highest Priority 111b – Lowest Priority.                                                                                                                                                                            |
| 8     | 1X_MODE          |                | This register bit determines the UDI buffering setup (priority versus port). For additional programming information, see Section 2.3.13.2.                                                                                                                  |
|       |                  | 0              | UDI buffers are priority based                                                                                                                                                                                                                              |
|       |                  | 1              | UDI buffers are port based. This mode must be selected when using more than one 1x port                                                                                                                                                                     |
| 7–4   | PRESCALER_SELECT |                | Internal frequency prescaler, used to drive the request to response<br>timers. These 4 bits are the prescaler reload value allowing division of<br>the DMA clock by a range from 1 up to 16. Setting should reflect the<br>device DMA frequency in MHz.     |
|       |                  | 0000b          | Sets the internal clock frequency Min 44.7 and Max 89.5                                                                                                                                                                                                     |
|       |                  | 0001b          | Sets the internal clock frequency Min 89.5 and Max 179.0                                                                                                                                                                                                    |
|       |                  | 0010b          | Sets the internal clock frequency Min 134.2 and Max 268.4                                                                                                                                                                                                   |
|       |                  | 0011b          | Sets the internal clock frequency Min 180.0 and Max 360.0                                                                                                                                                                                                   |
|       |                  | 0100b          | Sets the internal clock frequency Min 223.7 and Max 447.4                                                                                                                                                                                                   |
|       |                  | 0101b          | Sets the internal clock frequency Min 268.4 and Max 536.8                                                                                                                                                                                                   |
|       |                  | 0110b          | Sets the internal clock frequency Min 313.2 and Max 626.4                                                                                                                                                                                                   |
|       |                  | 0111b          | Sets the internal clock frequency Min 357.9 and Max 715.8                                                                                                                                                                                                   |
|       |                  | 1000b<br>1001b | sets the internal clock frequency Min 402.7 and Max 805.4                                                                                                                                                                                                   |
|       |                  | 1010b          | Sets the internal clock frequency Min 447.4 and Max 894.8<br>Sets the internal clock frequency Min 492.1 and Max 984.2                                                                                                                                      |
|       |                  | 1010b          | Sets the internal clock frequency Min 492.1 and Max 904.2<br>Sets the internal clock frequency Min 536.9 and Max 1073.8                                                                                                                                     |
|       |                  | 1100b          | Sets the internal clock frequency Min 530.9 and Max 1073.0                                                                                                                                                                                                  |
|       |                  | 1101b          | Sets the internal clock frequency Min 626.3 and Max 1252.6                                                                                                                                                                                                  |
|       |                  | 1110b          | Sets the internal clock frequency Min 671.1 and Max 1342.2                                                                                                                                                                                                  |
|       |                  | 1111b          | Sets the internal clock frequency Min 715.8 and Max 1431.6                                                                                                                                                                                                  |

## Table 43. Peripheral Settings Control Register (PER\_SET\_CNTL) Field Descriptions (continued)

| Bit | Field  | Value | Description                                                                             |
|-----|--------|-------|-----------------------------------------------------------------------------------------|
| 3   | ENPLL4 | 0     | Not used. Should always be programmed as "0". See Section 2.3.2.1 to enable SERDES PLL. |
| 2   | ENPLL3 | 0     | Not used. Should always be programmed as "0". See Section 2.3.2.1 to enable SERDES PLL. |
| 1   | ENPLL2 | 0     | Not used. Should always be programmed as "0". See Section 2.3.2.1 to enable SERDES PLL. |
| 0   | ENPLL1 | 0     | Not used. Should always be programmed as "0". See Section 2.3.2.1 to enable SERDES PLL. |



#### SRIO Registers

## 5.5 Peripheral Global Enable Register (GBL\_EN)

GBL\_EN is implemented with a single enable bit for the entire SRIO peripheral. This bit is logically ORed with the reset input to the module and is fanned out to all logical blocks within the peripheral. GBL\_EN is shown in Figure 66 and described in Table 44. For additional programming information, see Section 2.3.10.

### Figure 66. Peripheral Global Enable Register (GBL\_EN) (Address Offset 0030h)

| 31       | 1 | 0     |
|----------|---|-------|
| Reserved |   | EN    |
| R-0      |   | R/W-0 |
|          |   |       |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

#### Table 44. Peripheral Global Enable Register (GBL\_EN) Field Descriptions

| Bit  | Field    | Value     | Description                                                                        |
|------|----------|-----------|------------------------------------------------------------------------------------|
| 31–1 | Reserved | 00000000h | These read-only bits return 0s when read.                                          |
| 0    | EN       |           | Global enable. This bit controls reset to all clock domains within the peripheral. |
|      |          | 0         | The peripheral is to be disabled (held in reset with clocks disabled).             |
|      |          | 1         | The peripheral is to be enabled.                                                   |

## 5.6 Peripheral Global Enable Status Register (GBL\_EN\_STAT)

The peripheral global enable status register (GBL\_EN\_STAT) is shown in Figure 67 and described in Table 45. For additional programming information, see Section 2.3.10.

## Figure 67. Peripheral Global Enable Status Register (GBL\_EN\_STAT) - Address 0034h

| 31               |                  |                  |                  |                  |                  |                  | 24               |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
|                  |                  |                  | Rese             | erved            |                  |                  |                  |
|                  |                  |                  | R                | -0               |                  |                  |                  |
| 23               |                  |                  |                  |                  |                  |                  | 16               |
|                  |                  |                  | Rese             | erved            |                  |                  |                  |
|                  |                  |                  | R                | -0               |                  |                  |                  |
| 15               |                  |                  |                  |                  | 10               | 9                | 8                |
|                  |                  | Rese             | erved            |                  |                  | BLK8_EN_<br>STAT | BLK7_EN_<br>STAT |
|                  | R-0 R-1 R-1      |                  |                  |                  |                  |                  | R-1              |
| 7                | 6                | 5                | 4                | 3                | 2                | 1                | 0                |
| BLK6_EN_<br>STAT | BLK5_EN_<br>STAT | BLK4_EN_<br>STAT | BLK3_EN_<br>STAT | BLK2_EN_<br>STAT | BLK1_EN_<br>STAT | BLK0_EN_<br>STAT | GBL_EN_<br>STAT  |
| R-1              |

LEGEND: R = Read only; -n = Value after reset

### Table 45. Peripheral Global Enable Status Register (GBL\_EN\_STAT) Field Descriptions

| Bit   | Field        | Value | Description                                                                                                                                    |
|-------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–10 | Reserved     | 0     | These read-only bits return 0s when read.                                                                                                      |
| 9     | BLK8_EN_STAT |       | Block 8 enable status. Logical block 8 is SRIO port 3.                                                                                         |
|       |              | 0     | Logical block 8 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 8 is enabled with its clock running.                                                                                             |
| 8     | BLK7_EN_STAT |       | Block 7 enable status. Logical block 7 is SRIO port 2.                                                                                         |
|       |              | 0     | Logical block 7 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 7 is enabled with its clock running.                                                                                             |
| 7     | BLK6_EN_STAT |       | Block 6 enable status. Logical block 6 is SRIO port 1.                                                                                         |
|       |              | 0     | Logical block 6 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 6 is enabled with its clock running.                                                                                             |
| 6     | BLK5_EN_STAT |       | Block 5 enable status. Logical block 5 is SRIO port 0.                                                                                         |
|       |              | 0     | Logical block 5 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 5 is enabled with its clock running.                                                                                             |
| 5     | BLK4_EN_STAT |       | Block 4 enable status. Logical block 4 is the message receive unit (RXU).                                                                      |
|       |              | 0     | Logical block 4 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 4 is enabled with its clock running.                                                                                             |
| 4     | BLK3_EN_STAT |       | Block 3 enable status. Logical block 3 is the message transmit unit (TXU).                                                                     |
|       |              | 0     | Logical block 3 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 3 is enabled with clock running.                                                                                                 |
| 3     | BLK2_EN_STAT |       | Block 2 enable status. Logical block 2 is the memory access unit (MAU).                                                                        |
|       |              | 0     | Logical block 2 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 2 is enabled with its clock running.                                                                                             |
| 2     | BLK1_EN_STAT |       | Block 1 enable status. Logical block 1 is the Load/Store module, which is comprised of the four Load/Store units (LSU1, LSU2, LSU3, and LSU4). |
|       |              | 0     | Logical block 1 is in reset with its clock off.                                                                                                |
|       |              | 1     | Logical block 1 is enabled with its clock running.                                                                                             |



## Table 45. Peripheral Global Enable Status Register (GBL\_EN\_STAT) Field Descriptions (continued)

| Bit | Field        | Value | Description                                                                                                  |
|-----|--------------|-------|--------------------------------------------------------------------------------------------------------------|
| 1   | BLK0_EN_STAT |       | Block 0 enable status. Logical block 0 is the set of memory-mapped registers (MMRs) for the SRIO peripheral. |
|     |              | 0     | Logical block 0 is in reset with its clock off.                                                              |
|     |              | 1     | Logical block 0 is enabled with its clock running.                                                           |
| 0   | GBL_EN_STAT  |       | Global enable status                                                                                         |
|     |              | 0     | The peripheral is in reset with all its clocks off.                                                          |
|     |              | 1     | The peripheral is enabled with all its clocks running.                                                       |

## 5.7 Block n Enable Register (BLKn\_EN)

There are nine of these registers, one for each of nine logical blocks in the peripheral. The registers and the blocks they support are listed in Table 46. The general form for a block *n* enable register (BLK*n*\_EN) is shown in Figure 68 and described in Table 47. For additional programming information, see Section 2.3.10.

| Register | Address Offset | Associated Block                                                                    |
|----------|----------------|-------------------------------------------------------------------------------------|
| BLK0_EN  | 0038h          | Logical block 0: the set of memory-mapped control registers for the SRIO peripheral |
| BLK1_EN  | 0040h          | Logical block 1: the Load/Store module (the four LSUs and supporting logic)         |
| BLK2_EN  | 0048h          | Logical block 2: the memory access unit (MAU)                                       |
| BLK3_EN  | 0050h          | Logical block 3: the message transmit unit (TXU)                                    |
| BLK4_EN  | 0058h          | Logical block 4: the message receive unit (RXU).                                    |
| BLK5_EN  | 0060h          | Logical block 5: SRIO port 0                                                        |
| BLK6_EN  | 0068h          | Logical block 6: SRIO port 1.                                                       |
| BLK7_EN  | 0070h          | Logical block 7: SRIO port 2.                                                       |
| BLK8_EN  | 0078h          | Logical block 8: SRIO port 3.                                                       |

#### Table 46. Block *n* Enable Registers and the Associated Blocks

### Figure 68. Block *n* Enable Register (BLK*n*\_EN)

| 31 1     | 0     |
|----------|-------|
| Reserved | EN    |
| R-0      | R/W-1 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

## Table 47. Block *n* Enable Register (BLK*n*\_EN) Field Descriptions

| Bit  | Field    | Value | Description                                                     |  |
|------|----------|-------|-----------------------------------------------------------------|--|
| 31-1 | Reserved | 0     | leserved                                                        |  |
| 0    | EN       |       | lock <i>n</i> enable                                            |  |
|      |          | 0     | gical block <i>n</i> is to be reset with its clock off.         |  |
|      |          | 1     | Logical block <i>n</i> is to be enabled with its clock running. |  |



## 5.8 Block n Enable Status Register (BLKn\_EN\_STAT)

There are nine of these registers, one for each of nine logical blocks in the peripheral. The registers and the blocks they support are listed in Table 48. The general form for a block *n* enable status register (BLK*n*\_EN\_STAT) is shown in Figure 69 and described in Table 49. For additional programming information, see Section 2.3.10.

| Register     | Address Offset | Associated Block                                                                    |
|--------------|----------------|-------------------------------------------------------------------------------------|
| BLK0_EN_STAT | 003Ch          | Logical block 0: the set of memory-mapped control registers for the SRIO peripheral |
| BLK1_EN_STAT | 0044h          | Logical block 1: the Load/Store module (the four LSUs and supporting logic)         |
| BLK2_EN_STAT | 004Ch          | Logical block 2: the memory access unit (MAU)                                       |
| BLK3_EN_STAT | 0054h          | Logical block 3: the message transmit unit (TXU)                                    |
| BLK4_EN_STAT | 005Ch          | Logical block 4: the message receive unit (RXU).                                    |
| BLK5_EN_STAT | 0064h          | Logical block 5: SRIO port 0                                                        |
| BLK6_EN_STAT | 006Ch          | Logical block 6: SRIO port 1.                                                       |
| BLK7_EN_STAT | 0074h          | Logical block 7: SRIO port 2.                                                       |
| BLK8_EN_STAT | 007Ch          | Logical block 8: SRIO port 3.                                                       |

### Figure 69. Block n Enable Status Register (BLKn\_EN)

| _311     | 0       |
|----------|---------|
| Reserved | EN_STAT |
| R-0      | R/W-1   |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

## Table 49. Block n Enable Status Register (BLKn\_EN\_STAT) Field Descriptions

| Bit  | Field    | Value | Description                                               |  |
|------|----------|-------|-----------------------------------------------------------|--|
| 31-1 | Reserved | 0     | hese read-only bits return 0s when read.                  |  |
| 0    | EN_STAT  |       | lock n enable status                                      |  |
|      |          | 0     | pgical block <i>n</i> is reset with its clock off.        |  |
|      |          | 1     | Logical block <i>n</i> is enabled with its clock running. |  |



## 5.9 RapidIO DEVICEID1 Register (DEVICEID\_REG1)

The RapidIO DEVICEID1 register (DEVICEID\_REG1) is shown in Figure 70 and described in Table 50.

## Figure 70. RapidIO DEVICEID1 Register (DEVICEID\_REG1) (Offset 0080h)

| 31 |          | 24    | 23       | 16 |
|----|----------|-------|----------|----|
|    | Reserved |       | 8BNODEID |    |
|    | R-00h    |       | R/W-FFh  |    |
| 15 |          |       |          | 0  |
|    |          | 16BN  | ODEID    |    |
|    |          | R/W-I | FFFh     |    |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

## Table 50. RapidIO DEVICEID1 Register (DEVICEID\_REG1) Field Descriptions

| Bit   | Field     | Value       | Description                                                                                                                                                                            |
|-------|-----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24 | Reserved  | 0           | Reserved                                                                                                                                                                               |
| 23–16 | 8BNODEID  | 00h–FFh     | This value is equal to the value of the RapidIO Base Device ID CSR. The CPU must read the CSR value and set this register, so that outgoing packets contain the correct SOURCEID value |
| 15–0  | 16BNODEID | 0000h-FFFFh | This value is equal to the value of the RapidIO Base Device ID CSR. The CPU must read the CSR value and set this register, so that outgoing packets contain the correct SOURCEID value |



SRIO Registers

## 5.10 RapidIO DEVICEID2 Register (DEVICEID\_REG2)

The RapidIO DEVICEID2 register (DEVICEID\_REG2 is shown in Figure 71 and described in Table 51. For additional programming information, see Section 2.3.15.1 and Section 2.3.15.3.

## Figure 71. RapidIO DEVICEID2 Register (DEVICEID\_REG2) (Offset 0x0084)

| 31 |          | 24    | 23   |          | 16 |
|----|----------|-------|------|----------|----|
|    | Reserved |       |      | 8BNODEID |    |
|    | R-00h    |       |      | R/W-FFh  |    |
| 15 |          |       |      |          | 0  |
|    |          | 16BNO | DEID |          |    |
|    |          | R-FFI | FFh  |          |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 51. RapidIO DEVICEID2 Register (DEVICEID\_REG2) Field Descriptions

| Bit   | Field     | Value       | Description                                                                                                                      |
|-------|-----------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31–24 | Reserved  | 0           | Reserved                                                                                                                         |
| 23–16 | 8BNODEID  | 00h–FFh     | This is a secondary supported DeviceID checked against an incoming packet's DestID field. Typically used for Multi-cast support. |
| 15–0  | 16BNODEID | 0000h-FFFFh | This is a secondary supported DeviceID checked against an incoming packet's DestID field. Typically used for Multi-cast support. |

## 5.11 Packet Forwarding Register n for 16-Bit Device IDs (PF\_16B\_CNTLn)

There are four of these registers (see Table 52). The general form of a packet forwarding register for 16-bit DeviceIDs is shown in Figure 72 and described in Table 53. For additional programming information, see Section 2.3.15 and Section 2.3.15.3.

| Table 52. PF_16B_CNTL Registers |                |  |  |  |
|---------------------------------|----------------|--|--|--|
| Register                        | Address Offset |  |  |  |
| PF_16B_CNTL0                    | 0090h          |  |  |  |
| PF_16B_CNTL1                    | 0098h          |  |  |  |
| PF_16B_CNTL2                    | 00A0h          |  |  |  |
| PF_16B_CNTL3                    | 00A8h          |  |  |  |

## Figure 72. Packet Forwarding Register *n* for 16-Bit Device IDs (PF\_16B\_CNTL*n*)

| 31 16                | 15 0                  |
|----------------------|-----------------------|
| 16BIT_DEVID_UP_BOUND | 16BIT_DEVID_LOW_BOUND |
| R/W-FFFFh            | R/W-FFFFh             |

LEGEND: R/W = Read/Write; -*n* = Value after reset

## Table 53. Packet Forwarding Register *n* for 16-Bit DeviceIDs (PF\_16B\_CNTL*n*) Field Descriptions

| Bit   | Field                 | Value       | Description                                                                               |
|-------|-----------------------|-------------|-------------------------------------------------------------------------------------------|
| 31–16 | 16BIT_DEVID_UP_BOUND  | 0000h-FFFFh | Upper 16-bit DeviceID boundary. DestID above this range cannot use the table entry.       |
| 15–0  | 16BIT_DEVID_LOW_BOUND | 0000h-FFFFh | Lower 16-bit DeviceID boundary. DestID lower than this number cannot use the table entry. |



## 5.12 Packet Forwarding Register n for 8-Bit Device IDs (PF\_8B\_CNTLn)

There are four of these registers (see Table 54). The general form of a packet forwarding register for 16-bit DeviceIDs is shown in Figure 73 and described in Table 55. For additiona programming information see Section 2.3.15 and and Section 2.3.15.3.

| Table 54. PF_8B_CNTL Registers |       |  |  |  |
|--------------------------------|-------|--|--|--|
| Register Address Offset        |       |  |  |  |
| PF_8B_CNTL0                    | 0094h |  |  |  |
| PF_8B_CNTL1                    | 009Ch |  |  |  |
| PF_8B_CNTL2                    | 00A4h |  |  |  |
| PF_8B_CNTL3                    | 00ACh |  |  |  |

## Figure 73. Packet Forwarding Register *n* for 8-Bit Device IDs (PF\_8B\_CNTL*n*)

| 31 |                      | 18 | 17              | 16 |
|----|----------------------|----|-----------------|----|
|    | Reserved             |    | OUT_BOU<br>PORT |    |
|    | R-0                  |    | R/W-3           | 3  |
| 15 |                      |    |                 | 8  |
|    | 8BIT_DEVID_UP_BOUND  |    |                 |    |
|    | R/W-FFh              |    |                 |    |
| 7  |                      |    |                 | 0  |
|    | 8BIT_DEVID_LOW_BOUND |    |                 |    |
|    | R/W-FFh              |    |                 |    |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

#### Table 55. Packet Forwarding Register n for 8-Bit DeviceIDs (PF\_8B\_CNTLn) Field Descriptions

| Bit   | Field                | Value   | Description                                                                                              |
|-------|----------------------|---------|----------------------------------------------------------------------------------------------------------|
| 31–18 | Reserved             | 0       | Reserved                                                                                                 |
| 17–16 | OUT_BOUND_PORT       | 0–3     | Output port number for packets whose DestID falls within the 8-bit or 16-bit range for this table entry. |
| 15–8  | 8BIT_DEVID_UP_BOUND  | 00h–FFh | Upper 8-bit DeviceID boundary. DestID above this range cannot use the table entry.                       |
| 7–0   | 8BIT_DEVID_LOW_BOUND | 00h–FFh | Lower 8-bit DeviceID boundary. DestID lower than this number cannot use the table entry.                 |

## 5.13 SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL)

There are four of these registers, to support four ports (see ). The general form for a SERDES receive channel configuration register is summarized by Figure 74 and Table 57. See Section 2.3.2.2 for a complete explanation of the programming of these registers.

## Table 56. SERDES\_CFGRXn\_CNTL Registers and the Associated Ports

| Register           | Address Offset | Associated Port             |
|--------------------|----------------|-----------------------------|
| SERDES_CFGRX0_CNTL | 0100h          | Port 0                      |
| SERDES_CFGRX1_CNTL | 0104h          | Port 1                      |
| SERDES_CFGRX2_CNTL | 0108h          | Port 2 (TMS320TCI6482 Only) |
| SERDES_CFGRX3_CNTL | 010Ch          | Port 3 (TMS320TCI6482 Only) |

## Figure 74. SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL)

| 31    |    |    |         |    |     |    | 26 | 25             |     | 24  | 23    | 22 |       |   |      | 19       | ) · | 18 |           | 16    |
|-------|----|----|---------|----|-----|----|----|----------------|-----|-----|-------|----|-------|---|------|----------|-----|----|-----------|-------|
|       |    |    | Reserve | ed |     |    |    | Rese<br>(write |     |     | —     |    |       |   | EQ   |          |     |    | CDR       |       |
|       |    |    | R-0     |    |     |    |    | R/V            | V-0 |     | R-0   |    |       | R | /W-0 |          |     |    | R/W-0     |       |
| 15    | 14 | 13 |         | 12 | 11  | 10 |    |                | 8   |     | 7     | 6  |       | 5 | 4    |          |     | 2  | 1         | 0     |
| LOS   |    |    | ALIGN   |    | _   |    |    | ERM<br>e 001b) |     | INV | 'PAIR |    | RATE  |   |      | BUSWIDTH | ł   |    | (write 0) | ENRX  |
| R/W-0 |    |    | R/W-0   |    | R-0 |    | R  | /W-0           |     | R/  | 'W-0  |    | R/W-0 |   |      | R/W-0    |     |    | R/W-0     | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

## Table 57. SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL) Field Descriptions

| Bit   | Field    | Value       | Description                                                                                                                                                                                    |
|-------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–26 | Reserved | 000000b     | These read-only bits return 0s when read.                                                                                                                                                      |
| 25–24 | Reserved | 00b         | Always write 0s to these reserved bits.                                                                                                                                                        |
| 23    | Reserved | 0           | This read-only bit returns 0 when read.                                                                                                                                                        |
| 22–19 | EQ       | 0000b-1111b | Equalizer. Enables and configures the adaptive equalizer to compensate for loss in the transmission media. For the selectable values, see Table 58.                                            |
| 18–16 | CDR      |             | Clock/data recovery. Configures the clock/data recovery algorithm.                                                                                                                             |
|       |          | 000b        | First order. Phase offset tracking up to $\pm 488$ ppm.                                                                                                                                        |
|       |          | 001b        | Second order. Highest precision frequency offset matching but poorest response to changes in frequency offset, and longest lock time. Suitable for use in systems with fixed frequency offset. |
|       |          | 010b        | Second order. Medium precision frequency offset matching, frequency offset change response, and lock time.                                                                                     |
|       |          | 011b        | Second order. Best response to changes in frequency offset and fastest lock time, but lowest precision frequency offset matching. Suitable for use in systems with spread spectrum clocking.   |
|       |          | 100b        | First order with fast lock. Phase offset tracking up to $\pm$ 1953 ppm in the presence of10101010 training pattern, and $\pm$ 448 ppm otherwise.                                               |
|       |          | 101b        | Second order with fast lock. As per setting 001, but with improved response to changes in frequency offset when not close to lock.                                                             |
|       |          | 110b        | Second order with fast lock. As per setting 010, but with improved response to changes in frequency offset when not close to lock.                                                             |
|       |          | 111b        | Second order with fast lock. As per setting 011, but with improved response to changes in frequency offset when not close to lock.                                                             |



# Table 57. SERDES Receive Channel Configuration Register n (SERDES\_CFGRXn\_CNTL) Field Descriptions (continued)

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                               |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–14 | LOS      |       | Loss of signal. Enables loss of signal detection with 2 selectable thresholds.                                                                                                                                                                                                                                                                            |
|       |          | 00b   | Disabled. Loss of signal detection disabled.                                                                                                                                                                                                                                                                                                              |
|       |          | 01b   | High threshold. Loss of signal detection threshold in the range 85 to $195 mV_{dfpp}$ . This setting is suitable for Infiniband.                                                                                                                                                                                                                          |
|       |          | 10b   | Low threshold. Loss of signal detection threshold in the range 65 to $175 mV_{dfpp}$ . This setting is suitable for PCI-E and S-ATA.                                                                                                                                                                                                                      |
|       |          | 11b   | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 13–12 | ALIGN    |       | Symbol alignment. Enables internal or external symbol alignment.                                                                                                                                                                                                                                                                                          |
|       |          | 00b   | Alignment disabled. No symbol alignment will be performed while this setting is selected, or when switching to this selection from another.                                                                                                                                                                                                               |
|       |          | 01b   | Comma alignment enabled. Symbol alignment will be performed whenever a misaligned comma symbol is received.                                                                                                                                                                                                                                               |
|       |          | 10b   | Alignment jog. The symbol alignment will be adjusted by one bit position when this mode is selected (that is, the ALIGN value changes from 0xb to 1xb).                                                                                                                                                                                                   |
|       |          | 11b   | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 11    | Reserved | 0     | This read-only bit returns 0 when read.                                                                                                                                                                                                                                                                                                                   |
| 10–8  | TERM     | 001b  | Input termination. The only valid value for this field is 001b. This value sets the common point to 0.8 VDDT and supports AC coupled systems using CML transmitters. The transmitter has no effect on the receiver common mode, which is set to optimize the input sensitivity of the receiver. Common mode termination is via a 50 pF capacitor to VSSA. |
| 7     | INVPAIR  |       | Invert polarity. Inverts polarity of RIORXn and RIORXn.                                                                                                                                                                                                                                                                                                   |
|       |          | 0     | Normal polarity. RIORXn is considered to be positive data and RIORXn negative.                                                                                                                                                                                                                                                                            |
|       |          | 1     | Inverted polarity. RIORXn is considered to be negative data and RIORXn positive.                                                                                                                                                                                                                                                                          |
| 6–5   | RATE     |       | Operating rate. Selects full, half, or quarter rate operation.                                                                                                                                                                                                                                                                                            |
|       |          | 00b   | Full rate. Two data samples taken per PLL output clock cycle.                                                                                                                                                                                                                                                                                             |
|       |          | 01b   | Half rate. One data sample taken per PLL output clock cycle.                                                                                                                                                                                                                                                                                              |
|       |          | 10b   | Quarter rate. One data sample taken every two PLL output clock cycles.                                                                                                                                                                                                                                                                                    |
|       |          | 11b   | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 4–2   | BUSWIDTH | 000b  | Bus width. Always write 000b to this field, to indicate a 10-bit-wide parallel bus to the clock. All other values are reserved. See Section 2.3.2.1 for an explanation of the bus.                                                                                                                                                                        |
| 1     | Reserved | 0     | Always write 0 to this reserved bit.                                                                                                                                                                                                                                                                                                                      |
| 0     | ENRX     |       | Enable receiver                                                                                                                                                                                                                                                                                                                                           |
|       |          | 0     | Disable this receiver.                                                                                                                                                                                                                                                                                                                                    |
|       |          | 1     | Enable this receiver.                                                                                                                                                                                                                                                                                                                                     |

## Table 58. EQ Bits

| CFGRX[22–19] | Low Freq Gain | Zero Freq (at e <sub>28</sub> (min)) |  |
|--------------|---------------|--------------------------------------|--|
| 0000b        | Maximum       | _                                    |  |
| 0001b        | Adaptive      | Adaptive                             |  |
| 001xb        | Reserved      |                                      |  |
| 01xxb        | Reserved      |                                      |  |

| CFGRX[22–19] | Low Freq Gain | Zero Freq (at e <sub>28</sub> (min)) |
|--------------|---------------|--------------------------------------|
| 1000b        | Adaptive      | 1084MHz                              |
| 1001b        |               | 805MHz                               |
| 1010b        |               | 573MHz                               |
| 1011b        |               | 402MHz                               |
| 1100b        |               | 304MHz                               |
| 1101b        |               | 216MHz                               |
| 1110b        |               | 156MHz                               |
| 1111b        |               | 135MHz                               |

## Table 58. EQ Bits (continued)



SRIO Registers

## 5.14 SERDES Transmit Channel Configuration Register n (SERDES\_CFGTXn\_CNTL)

There are four of these registers, to support four ports (see Table 59). The general form for a SERDES transmit channel configuration register is summarized by Figure 75 and Table 60. See Section 2.3.2.3 for a complete explanation of the programming for these registers.

### Table 59. SERDES\_CFGTXn\_CNTL Registers and the Associated Ports

| Register           | Address Offset | Associated Port             |
|--------------------|----------------|-----------------------------|
| SERDES_CFGTX0_CNTL | 0110h          | Port 0                      |
| SERDES_CFGTX1_CNTL | 0114h          | Port 1                      |
| SERDES_CFGTX2_CNTL | 0118h          | Port 2 (TMS320TCI6482 Only) |
| SERDES_CFGTX3_CNTL | 011Ch          | Port 3 (TMS320TCI6482 Only) |
|                    |                |                             |

### Figure 75. SERDES Transmit Channel Configuration Register n (SERDES\_CFGTXn\_CNTL)

| 31 |       |       |        |         |       |          |   | 17            | 16    |
|----|-------|-------|--------|---------|-------|----------|---|---------------|-------|
|    |       |       | Reserv | ved     |       |          |   |               | ENFTP |
|    |       |       | R-0    | )       |       |          |   |               | R/W-0 |
| 15 | 12    | 11    | 9 8    | 7       | 6     | 5 4      | 2 | 1             | 0     |
|    | DE    | SWING | СМ     | INVPAIR | RATE  | BUSWIDTH |   | <br>(write 0) | ENTX  |
|    | R/W-0 | R/W-0 | R/W-0  | R/W-0   | R/W-0 | R/W-0    |   | R/W-0         | R/W-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

## Table 60. SERDES Transmit Channel Configuration Register n (SERDES\_CFGTXn\_CNTL) Field Descriptions

| Bit   | Field    | Value       | Description                                                                                                                                                                                                                                                                                                          |
|-------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–17 | Reserved | 0           | These read-only bits return 0s when read.                                                                                                                                                                                                                                                                            |
| 16    | ENFTP    | 1           | Enables fixed phase relationship of transmit input clock with respect to transmit output clock. The only valid value for this field is 1b; all other values are reserved.                                                                                                                                            |
| 15–12 | DE       | 0000b–1111b | De-emphasis. Selects one of 15 output de-emphasis settings from 4.76 to 71.42%. De-emphasis provides a means to compensate for high frequency attenuation in the attached media. It causes the output amplitude to be smaller for bits which are not preceded by a transition than for bits which are. See Table 61. |
| 11–9  | SWING    | 000b–111b   | Output swing. Selects one of 8 output amplitude settings between 125 and 1250mV_{dfpp}. See Table 62.                                                                                                                                                                                                                |
| 8     | СМ       |             | Common mode. Adjusts the common mode to suit the termination at the attached receiver.                                                                                                                                                                                                                               |
|       |          | 0           | Normal common mode. Common mode not adjusted.                                                                                                                                                                                                                                                                        |
|       |          | 1           | Raised common mode. Common mode raised by 5% of $\ensuremath{e_{54}}$ .                                                                                                                                                                                                                                              |
| 7     | INVPAIR  |             | Invert polarity. Inverts the polarity of RIOTXn and RIOTXn.                                                                                                                                                                                                                                                          |
|       |          | 0           | Normal polarity. RIOTXn is considered to be positive data and RIOTXn negative.                                                                                                                                                                                                                                       |
|       |          | 1           | Inverted polarity. RIOTXn is considered to be negative data and RIOTXn positive.                                                                                                                                                                                                                                     |
| 6–5   | RATE     |             | Operating rate. Selects full, half, or quarter rate operation.                                                                                                                                                                                                                                                       |
|       |          | 00b         | Full rate. Two data samples taken per PLL output clock cycle.                                                                                                                                                                                                                                                        |
|       |          | 01b         | Half rate. One data sample taken per PLL output clock cycle.                                                                                                                                                                                                                                                         |
|       |          | 10b         | Quarter rate. One data sample taken every two PLL output clock cycles.                                                                                                                                                                                                                                               |
|       |          | 11b         | Reserved                                                                                                                                                                                                                                                                                                             |
| 4–2   | BUSWIDTH | 000b        | Bus width. Always write 000b to this field, to indicate a 10-bit-wide parallel bus to the clock. All other values are reserved. See Section 2.3.2.1 for an explanation of the bus.                                                                                                                                   |
| 1     | Reserved | 0           | Always write 0 to this reserved bit.                                                                                                                                                                                                                                                                                 |
|       |          |             |                                                                                                                                                                                                                                                                                                                      |



# Table 60. SERDES Transmit Channel Configuration Register n (SERDES\_CFGTXn\_CNTL) Field Descriptions (continued)

| Bit | Field | Value | Description               |
|-----|-------|-------|---------------------------|
| 0   | ENTX  |       | Enable transmitter        |
|     |       | 0     | Disable this transmitter. |
|     |       | 1     | Enable this transmitter.  |

|         | Amplitude | Reduction |
|---------|-----------|-----------|
| DE Bits | %         | dB        |
| 0000b   | 0         | 0         |
| 0001b   | 4.76      | -0.42     |
| 0010b   | 9.52      | -0.87     |
| 0011b   | 14.28     | -1.34     |
| 0100b   | 19.04     | -1.83     |
| 0101b   | 23.8      | -2.36     |
| 0110b   | 28.56     | -2.92     |
| 0111b   | 33.32     | -3.52     |
| 1000b   | 38.08     | -4.16     |
| 1001b   | 42.85     | -4.86     |
| 1010b   | 47.61     | -5.61     |
| 1011b   | 52.38     | -6.44     |
| 1100b   | 57.14     | -7.35     |
| 1101b   | 61.9      | -8.38     |
| 1110b   | 66.66     | -9.54     |
| 1111b   | 71.42     | -10.87    |

## Table 61. DE Bits of SERDES\_CFGTXn\_CNTL

| SWING Bits | Amplitude (mV <sub>dfpp</sub> ) |  |  |  |
|------------|---------------------------------|--|--|--|
| 000b       | 125                             |  |  |  |
| 001b       | 250                             |  |  |  |
| 010b       | 500                             |  |  |  |
| 011b       | 625                             |  |  |  |
| 100b       | 750                             |  |  |  |
| 101b       | 1000                            |  |  |  |
| 110b       | 1125                            |  |  |  |
| 111b       | 1250                            |  |  |  |

Table 62. SWING Bits of SERDES CFGTXn CNTL



## 5.15 SERDES Macro Configuration Register n (SERDES\_CFGn\_CNTL)

There are four of these registers, to support four ports (see Table 63). The general form for a SERDES transmit channel configuration register is summarized by Figure 76 and Table 64. See Section 2.3.2.1 for a complete explanation of the programming of this register.

#### Table 63. SERDES\_CFGn\_CNTL Registers and the Associated Ports

| Register         | Address Offset | Associated Port                    |
|------------------|----------------|------------------------------------|
| SERDES_CFG0_CNTL | 0120h          | Port 0, Port 1, Port 2, and Port 3 |
| SERDES_CFG1_CNTL | 0124h          | Not Used. Program as 0x0000000     |
| SERDES_CFG2_CNTL | 0128h          | Not Used. Program as 0x0000000     |
| SERDES_CFG3_CNTL | 012Ch          | Not Used. Program as 0x00000000    |

### Figure 76. SERDES Macro Configuration Register n (SERDES\_CFGn\_CNTL)

| 31       |    |       |          |    |       |   | 16    |
|----------|----|-------|----------|----|-------|---|-------|
|          |    | Re    | eserved  |    |       |   |       |
|          |    |       | R-0      |    |       |   |       |
| 15       | 10 | 9     | 8 7      | 65 |       | 1 | 0     |
| Reserved |    | LB    | Reserved |    | MPY   |   | ENPLL |
| R-0      |    | R/W-0 | R-0      |    | R/W-0 |   | R/W-0 |
|          |    |       |          |    |       |   |       |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 64. SERDES Macro Configuration Register n (SERDES\_CFGn\_CNTL) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–10 | Reserved | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9–8   | LB       |       | Loop bandwidth. Specify loop bandwidth settings. Jitter on the reference clock will degrade both the transmit eye and receiver jitter tolerance thereby impairing system performance. Performance of the integrated PLL can be optimized according to the jitter characteristics of the reference clock via the LB field.                                                                                                                                                                                                                                                            |
|       |          | 00b   | Frequency dependent bandwidth. The PLL bandwidth is set to a twelfth of the frequency of RIOCLK/RIOCLK. This setting is suitable for most systems that input the reference clock via a low jitter input cell, and is required for standards compliance                                                                                                                                                                                                                                                                                                                               |
|       |          | 01b   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |          | 10b   | Low bandwidth. The PLL bandwidth is set to a twentieth of the frequency of RIOCLK/RIOCLK, or 3MHz (whichever is larger). In systems where the reference clock is directly input via a low jitter input cell, but is of lower quality, this setting may offer better performance. It will reduce the amount of reference clock jitter transferred through the PLL. However, it also increases the susceptibility to loop noise generated within the PLL itself. It is difficult to predict whether the improvement in the former will more than offset the degradation in the latter. |
|       |          | 11b   | High bandwidth. The PLL bandwidth is set to a eighth of the frequency of RIOCLK/RIOCLK. This is the setting appropriate for systems where the reference clock is cleaned through an ultra low jitter LC-based PLL. Standards compliance will be achieved even if the reference clock input to the cleaner PLL is outside the specification for the standard.                                                                                                                                                                                                                         |
| 7–6   | Reserved | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Bit | Field | Value  | Description                                                 |
|-----|-------|--------|-------------------------------------------------------------|
| 5–1 | MPY   |        | PLL multiply. Select PLL multiply factors between 4 and 60. |
|     |       | 00000b | 4x                                                          |
|     |       | 00001b | 5x                                                          |
|     |       | 00010b | 6x                                                          |
|     |       | 00011b | Reserved                                                    |
|     |       | 00100b | 8x                                                          |
|     |       | 00101b | 10x                                                         |
|     |       | 00110b | 12x                                                         |
|     |       | 00111b | 12.5x                                                       |
|     |       | 01000b | 15x                                                         |
|     |       | 01001b | 20x                                                         |
|     |       | 01010b | 25x                                                         |
|     |       | 01011b | Reserved                                                    |
|     |       | 01100b | Reserved                                                    |
|     |       | 01111b | Reserved                                                    |
|     |       | 1xxxxb | Reserved                                                    |
| 0   | ENPLL |        | Enable PLL                                                  |
|     |       | 0      | PLL disabled                                                |
|     |       | 1      | PLL enabled                                                 |

# Table 64. SERDES Macro Configuration Register n (SERDES\_CFGn\_CNTL) Field Descriptions (continued)



40

24

## 5.16 DOORBELLn Interrupt Condition Status Register (DOORBELLn\_ICSR)

The four doorbell interrupts are mapped to these registers (see Table 65). The general form of a doorbell interrupt condition status register is shown in Figure 77 and described in Table 66. For additional programming information, see Section 4.3.1 and Section 2.3.6.

#### Table 65. DOORBELL*n*\_ICSR Registers

| Register       | Address Offset |  |
|----------------|----------------|--|
| DOORBELL0_ICSR | 0200h          |  |
| DOORBELL1_ICSR | 0210h          |  |
| DOORBELL2_ICSR | 0220h          |  |
| DOORBELL3_ICSR | 0230h          |  |

#### Figure 77. Doorbell *n* Interrupt Condition Status Register (DOORBELL*n*\_ICSR)

| 31    |                                                                 |       |       |       |       |       |       |       |       |       |       |       |       |       | 16    |
|-------|-----------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       | Reserved                                                        |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
|       |                                                                 |       |       |       |       |       | R     | -0    |       |       |       |       |       |       |       |
| 15    | 14                                                              | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| ICS15 | ICS14                                                           | ICS13 | ICS12 | ICS11 | ICS10 | ICS9  | ICS8  | ICS7  | ICS6  | ICS5  | ICS4  | ICS3  | ICS2  | ICS1  | ICS0  |
| R/W-0 | R/W-0                                                           | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| LEGEN | LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset |       |       |       |       |       |       |       |       |       |       |       |       |       |       |

#### Table 66. DOORBELLn Interrupt Condition Status Register (DOORBELLn\_ICSR) Field Descriptions

| Bit   | Field         | Value | Description                                                                      |
|-------|---------------|-------|----------------------------------------------------------------------------------|
| 31–16 | Reserved      | 0     | These read-only bits return 0s when read.                                        |
| 15–0  | ICSx          |       | Doorbell <i>n</i> interrupt condition status bit                                 |
|       | (x = 15 to 0) | 0     | Bit <i>x</i> of the doorbell information value is 0.                             |
|       |               | 1     | Bit $x$ of the doorbell information value is 1, generating an interrupt request. |

24

40

## 5.17 DOORBELLn Interrupt Condition Clear Register (DOORBELLn\_ICCR)

The four doorbells interrupts that are mapped are cleared by this register (see Table 67). The general form of a doorbell interrupt condition clear register is shown in Figure 78 and described in Table 68. For additional programming information, see Section 4.4.1 and Section 2.3.6.

## Table 67. DOORBELLn\_ICCR Registers

| Register       | Address Offset |  |
|----------------|----------------|--|
| DOORBELL0_ICCR | 0208h          |  |
| DOORBELL1_ICCR | 0218h          |  |
| DOORBELL2_ICCR | 0228h          |  |
| DOORBELL3_ICCR | 0238h          |  |

## Figure 78. Doorbell *n* Interrupt Condition Clear Register (DOORBELL*n*\_ICCR)

| 31    |                                                               |       |       |       |       |      |      |       |      |      |      |      |      |      | 16   |
|-------|---------------------------------------------------------------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------|
|       |                                                               |       |       |       |       |      | Rese | erved |      |      |      |      |      |      |      |
|       |                                                               |       |       |       |       |      | R    | -0    |      |      |      |      |      |      |      |
| 15    | 14                                                            | 13    | 12    | 11    | 10    | 9    | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15 | ICC14                                                         | ICC13 | ICC12 | ICC11 | ICC10 | ICC9 | ICC8 | ICC7  | ICC6 | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |
| W-0   | W-0                                                           | W-0   | W-0   | W-0   | W-0   | W-0  | W-0  | W-0   | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  |
| LEGEN | LEGEND: W = Write only; R = Read only; -n = Value after reset |       |       |       |       |      |      |       |      |      |      |      |      |      |      |

## Table 68. DOORBELLn Interrupt Condition Clear Register (DOORBELLn\_ICCR) Field Descriptions

| Bit   | Field         | Value | Description                                                                             |
|-------|---------------|-------|-----------------------------------------------------------------------------------------|
| 31–16 | Reserved      | 0     | These read-only bits return 0s when read.                                               |
| 15–0  | ICCx          |       | Doorbell <i>n</i> interrupt condition clear bit                                         |
|       | (x = 15 to 0) | 0     | No effect                                                                               |
|       |               | 1     | Clear bit $x$ of the corresponding doorbell interrupt condition status register (ICSR). |



## 5.18 RX CPPI Interrupt Status Register (RX\_CPPI\_ICSR)

The bits in this register indicate any active interrupt requests from RX buffer descriptor queues. The RX CPPI interrupt status register (RX\_CPPI\_ICSR) is shown in Figure 79 and described in Table 69. For additional programming information, see Section 4.3.2.

### Figure 79. RX CPPI Interrupt Condition Status Register (RX\_CPPI\_ICSR) - Address Offset 0240h

| 31    |                                                                 |       |       |       |       |       |       |       |       |       |       |       |       |       | 16    |
|-------|-----------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       |                                                                 |       |       |       |       |       | Rese  | erved |       |       |       |       |       |       |       |
|       |                                                                 |       |       |       |       |       | R     | -0    |       |       |       |       |       |       |       |
| 15    | 14                                                              | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| ICS15 | ICS14                                                           | ICS13 | ICS12 | ICS11 | ICS10 | ICS9  | ICS8  | ICS7  | ICS6  | ICS5  | ICS4  | ICS3  | ICS2  | ICS1  | ICS0  |
| R/W-0 | R/W-0                                                           | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| LEGEN | LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset |       |       |       |       |       |       |       |       |       |       |       |       |       |       |

#### Table 69. RX CPPI Interrupt Condition Status Register (RX\_CPPI\_ICSR) Field Descriptions

| Bit   | Field         | Value | Description                                                          |
|-------|---------------|-------|----------------------------------------------------------------------|
| 31–16 | Reserved      | 0     | These read-only bits return 0 when read.                             |
| 15–0  | ICSx          |       | RX CPPI interrupt status                                             |
|       | (x = 15 to 0) | 0     | RX buffer descriptor queue x has not generated an interrupt request. |
|       |               | 1     | RX buffer descriptor queue x has generated an interrupt request.     |

## 5.19 RX CPPI Interrupt Clear Register (RX\_CPPI\_ICCR)

This register is used to clear bits in RX\_CPPI\_ICSR to acknowledge interrupts from the RX buffer descriptor queues. The RX CPPI interrupt clear register (RX\_CPPI\_ICCR) is shown in Figure 80 and described in Table 70. For additional programming information, see Section 4.3.2.

## Figure 80. RX CPPI Interrupt Condition Clear Register (RX\_CPPI\_ICCR) - Address Offset 0248h

| 31    |                                                                 |       |       |       |       |      |      |       |      |      |      |      |      |      | 16   |
|-------|-----------------------------------------------------------------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------|
|       |                                                                 |       |       |       |       |      | Rese | erved |      |      |      |      |      |      |      |
|       |                                                                 |       |       |       |       |      | R    | -0    |      |      |      |      |      |      |      |
| 15    | 14                                                              | 13    | 12    | 11    | 10    | 9    | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15 | ICC14                                                           | ICC13 | ICC12 | ICC11 | ICC10 | ICC9 | ICC8 | ICC7  | ICC6 | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |
| W-0   | W-0                                                             | W-0   | W-0   | W-0   | W-0   | W-0  | W-0  | W-0   | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  |
| LEGEN | LEGEND: R = Read only; W = Write only; $-n$ = Value after reset |       |       |       |       |      |      |       |      |      |      |      |      |      |      |

Table 70. RX CPPI Interrupt Condition Clear Register (RX\_CPPI\_ICCR) Field Descriptions

| Bit   | Field         | Value | Description                            |  |  |  |  |  |
|-------|---------------|-------|----------------------------------------|--|--|--|--|--|
| 31–16 | Reserved      | 0     | ese read-only bits return 0 when read. |  |  |  |  |  |
| 15–0  | ICCx          |       | RX CPPI interrupt clear                |  |  |  |  |  |
|       | (x = 15 to 0) | 0     | No effect                              |  |  |  |  |  |
|       |               | 1     | Clear bit x of RX_CPPI_ICSR.           |  |  |  |  |  |



## 5.20 TX CPPI Interrupt Status Register (TX\_CPPI\_ICSR)

The bits in this register indicate any active interrupt requests from TX buffer descriptor queues. TX\_CPPI\_ICSR is shown in Figure 81 and described in Table 71.

## Figure 81. TX CPPI Interrupt Condition Status Register (TX\_CPPI\_ICSR) - Address Offset 0250h

| 31    |                                                                 |       |       |       |       |       |       |       |       |       |       |       |       |       | 16    |
|-------|-----------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       |                                                                 |       |       |       |       |       | Rese  | erved |       |       |       |       |       |       |       |
|       |                                                                 |       |       |       |       |       | R     | -0    |       |       |       |       |       |       |       |
| 15    | 14                                                              | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| ICS15 | ICS14                                                           | ICS13 | ICS12 | ICS11 | ICS10 | ICS9  | ICS8  | ICS7  | ICS6  | ICS5  | ICS4  | ICS3  | ICS2  | ICS1  | ICS0  |
| R/W-0 | R/W-0                                                           | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| LEGEN | LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset |       |       |       |       |       |       |       |       |       |       |       |       |       |       |

### Table 71. TX CPPI Interrupt Condition Status Register (TX\_CPPI\_ICSR) Field Descriptions

| Bit   | Field         | Value | Description                                                          |
|-------|---------------|-------|----------------------------------------------------------------------|
| 31–16 | Reserved      | 0     | These read-only bits return 0 when read.                             |
| 15–0  | ICSx          |       | TX CPPI interrupt status                                             |
|       | (x = 15 to 0) | 0     | TX buffer descriptor queue x has not generated an interrupt request. |
|       |               | 1     | TX buffer descriptor queue x has generated an interrupt request.     |

## 5.21 TX CPPI Interrupt Clear Register (TX\_CPPI\_ICCR)

This register is used to clear bits in TX\_CPPI\_ICSR to acknowledge interrupts from the TX buffer descriptor queues. TX\_CPPI\_ICCR is shown in Figure 82 and described in Table 72.

## Figure 82. TX CPPI Interrupt Condition Clear Register (TX\_CPPI\_ICCR) - Address Offset 0258h

| 31    |                                                                       |       |       |       |       |      |      |       |      |      |      |      |      |      | 16   |
|-------|-----------------------------------------------------------------------|-------|-------|-------|-------|------|------|-------|------|------|------|------|------|------|------|
|       |                                                                       |       |       |       |       |      | Rese | erved |      |      |      |      |      |      |      |
|       |                                                                       |       |       |       |       |      | R    | -0    |      |      |      |      |      |      |      |
| 15    | 14                                                                    | 13    | 12    | 11    | 10    | 9    | 8    | 7     | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ICC15 | ICC14                                                                 | ICC13 | ICC12 | ICC11 | ICC10 | ICC9 | ICC8 | ICC7  | ICC6 | ICC5 | ICC4 | ICC3 | ICC2 | ICC1 | ICC0 |
| W-0   | W-0                                                                   | W-0   | W-0   | W-0   | W-0   | W-0  | W-0  | W-0   | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  | W-0  |
| LEGEN | LEGEND: R = Read only; W = Write only; - <i>n</i> = Value after reset |       |       |       |       |      |      |       |      |      |      |      |      |      |      |

## Table 72. TX CPPI Interrupt Condition Clear Register (TX\_CPPI\_ICCR) Field Descriptions

| Bit   | Field         | Value | Description                              |
|-------|---------------|-------|------------------------------------------|
| 31–16 | Reserved      | 0     | These read-only bits return 0 when read. |
| 15–0  | ICCx          |       | TX CPPI interrupt clear                  |
|       | (x = 15 to 0) | 0     | No effect                                |
|       |               | 1     | Clear bit x of TX_CPPI_ICSR.             |

SRIO Registers

## 5.22 LSU Interrupt Condition Status Register (LSU\_ICSR)

Each of the status bits in this register indicates the occurrence of a particular type of transaction interrupt condition for a particular LSU. LSU\_ICSR is shown in Figure 83 and described in Table 73. For additional programming information, see Section 4.3.3.

### Figure 83. LSU Interrupt Condition Status Register (LSU\_ICSR) - Address Offset 0260h

| <     |          |           | Bits fo          | r LSU4     |       |       | >     | <     |       |       | Bits fo | r LSU3 |       |       | >     |
|-------|----------|-----------|------------------|------------|-------|-------|-------|-------|-------|-------|---------|--------|-------|-------|-------|
| 31    | 30       | 29        | 28               | 27         | 26    | 25    | 24    | 23    | 22    | 21    | 20      | 19     | 18    | 17    | 16    |
| ICS31 | ICS30    | ICS29     | ICS28            | ICS27      | ICS26 | ICS25 | ICS24 | ICS23 | ICS22 | ICS21 | ICS20   | ICS19  | ICS18 | ICS17 | ICS16 |
| R-0   | R-0      | R-0       | R-0              | R-0        | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0     | R-0    | R-0   | R-0   | R-0   |
| <     |          |           | Bits fo          | r LSU2     |       |       | >     | <     |       |       | Bits fo | r LSU1 |       |       | >     |
| 15    | 14       | 13        | 12               | 11         | 10    | 9     | 8     | 7     | 6     | 5     | 4       | 3      | 2     | 1     | 0     |
| ICS15 | ICS14    | ICS13     | ICS12            | ICS11      | ICS10 | ICS9  | ICS8  | ICS7  | ICS6  | ICS5  | ICS4    | ICS3   | ICS2  | ICS1  | ICS0  |
| R-0   | R-0      | R-0       | R-0              | R-0        | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0     | R-0    | R-0   | R-0   | R-0   |
| LEGEN | D: R = R | ead only; | - <i>n</i> = Val | ue after r | eset  |       |       |       |       |       |         |        |       |       |       |

#### Table 73. LSU Interrupt Condition Status Register (LSU\_ICSR) Field Descriptions

| Bit | Field | Value | Description                                                                                                                                                                                                                                                                                                                      |
|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | ICS31 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Packet not sent due to unavailable outbound credit at given priority.                                                                                                                                                                                                                         |
| 30  | ICS30 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use).                                                                                                                                                                                                  |
| 29  | ICS29 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Transaction was not sent due to DMA data transfer error.                                                                                                                                                                                                                                      |
| 28  | ICS28 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Transaction timeout occurred.                                                                                                                                                                                                                                                                 |
| 27  | ICS27 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Transaction was not sent due to unsupported transaction type or invalid field encoding.                                                                                                                                                                                                       |
| 26  | ICS26 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Transaction was not sent due to Xoff condition.                                                                                                                                                                                                                                               |
| 25  | ICS25 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Non-posted transaction received ERROR response, or error in response payload.                                                                                                                                                                                                                 |
| 24  | ICS24 | 0     | LSU4 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU4 interrupt condition detected. Transaction complete, No errors (posted/non-posted). Enable for this interrupt is ultimately controlled by the Interrupt Req bit of LSU4_REG4. This allows enabling/disabling on a per request basis. For optimum LSU performance, interrupt pacing should not be used on the LSU interrupts. |
| 23  | ICS23 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Packet not sent due to unavailable outbound credit at given priority.                                                                                                                                                                                                                         |
| 22  | ICS22 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use).                                                                                                                                                                                                  |
| 21  | ICS21 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Transaction was not sent due to DMA data transfer error.                                                                                                                                                                                                                                      |
| 20  | ICS20 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Transaction timeout occurred.                                                                                                                                                                                                                                                                 |

## Table 73. LSU Interrupt Condition Status Register (LSU\_ICSR) Field Descriptions (continued)

| Bit | Field | Value | Description                                                                                                                                                                                                                                                                                                                      |
|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19  | ICS19 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Transaction was not sent due to unsupported transaction type or invalid field encoding.                                                                                                                                                                                                       |
| 18  | ICS18 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Transaction was not sent due to Xoff condition.                                                                                                                                                                                                                                               |
| 17  | ICS17 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Non-posted transaction received ERROR response, or error in response payload.                                                                                                                                                                                                                 |
| 16  | ICS16 | 0     | LSU3 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU3 interrupt condition detected. Transaction complete, No errors (posted/non-posted). Enable for this interrupt is ultimately controlled by the Interrupt Req bit of LSU3_REG4. This allows enabling/disabling on a per request basis. For optimum LSU performance, interrupt pacing should not be used on the LSU interrupts. |
| 15  | ICS15 | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Packet not sent due to unavailable outbound credit at given priority.                                                                                                                                                                                                                         |
| 14  | ICS14 | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use).                                                                                                                                                                                                  |
| 13  | ICS13 | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Transaction was not sent due to DMA data transfer error.                                                                                                                                                                                                                                      |
| 12  | ICS12 | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Transaction timeout occurred.                                                                                                                                                                                                                                                                 |
| 11  | ICS11 | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Transaction was not sent due to unsupported transaction type or invalid field encoding.                                                                                                                                                                                                       |
| 10  | ICS10 | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Transaction was not sent due to Xoff condition.                                                                                                                                                                                                                                               |
| 9   | ICS9  | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Non-posted transaction received ERROR response, or error in response payload.                                                                                                                                                                                                                 |
| 8   | ICS8  | 0     | LSU2 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU2 interrupt condition detected. Transaction complete, No errors (posted/non-posted). Enable for this interrupt is ultimately controlled by the Interrupt Req bit of LSU2_REG4. This allows enabling/disabling on a per request basis. For optimum LSU performance, interrupt pacing should not be used on the LSU interrupts. |
| 7   | ICS7  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Packet not sent due to unavailable outbound credit at given priority.                                                                                                                                                                                                                         |
| 6   | ICS6  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Retry Doorbell response received or Atomic test-and-swap was not allowed (semaphore in use).                                                                                                                                                                                                  |
| 5   | ICS5  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Transaction was not sent due to DMA data transfer error.                                                                                                                                                                                                                                      |
| 4   | ICS4  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Transaction timeout occurred.                                                                                                                                                                                                                                                                 |
| 3   | ICS3  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Transaction was not sent due to unsupported transaction type or invalid field encoding.                                                                                                                                                                                                       |
| 2   | ICS2  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Transaction was not sent due to Xoff condition.                                                                                                                                                                                                                                               |



## Table 73. LSU Interrupt Condition Status Register (LSU\_ICSR) Field Descriptions (continued)

| Bit | Field | Value | Description                                                                                                                                                                                                                                                                                                                      |
|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | ICS1  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Non-posted transaction received ERROR response, or error in response payload.                                                                                                                                                                                                                 |
| 0   | ICS0  | 0     | LSU1 interrupt condition not detected.                                                                                                                                                                                                                                                                                           |
|     |       | 1     | LSU1 interrupt condition detected. Transaction complete, No errors (posted/non-posted). Enable for this interrupt is ultimately controlled by the Interrupt Req bit of LSU1_REG4. This allows enabling/disabling on a per request basis. For optimum LSU performance, interrupt pacing should not be used on the LSU interrupts. |

## 5.23 LSU Interrupt Condition Clear Register (LSU\_ICCR)

Setting a bit in this register clears the corresponding bit in LSU\_ICSR, to acknowledge the interrupt. LSU\_ICCR is shown in Figure 84 and described in Table 74. For additional programming information, see Section 4.3.3.

## Figure 84. LSU Interrupt Condition Clear Register (LSU\_ICCR) - Address Offset 0268h

| <     |          |            | Bits fo            | r LSU4      |       |       | >     | <     |       |       | Bits fo | r LSU3 |       |       | >     |
|-------|----------|------------|--------------------|-------------|-------|-------|-------|-------|-------|-------|---------|--------|-------|-------|-------|
| 31    | 30       | 29         | 28                 | 27          | 26    | 25    | 24    | 23    | 22    | 21    | 20      | 19     | 18    | 17    | 16    |
| ICC31 | ICC30    | ICC29      | ICC28              | ICC27       | ICC26 | ICC25 | ICC24 | ICC23 | ICC22 | ICC21 | ICC20   | ICC19  | ICC18 | ICC17 | ICC16 |
| W-0   | W-0      | W-0        | W-0                | W-0         | W-0   | W-0   | W-0   | W-0   | W-0   | W-0   | W-0     | W-0    | W-0   | W-0   | W-0   |
| <     |          |            | Bits fo            | r LSU2      |       |       | >     | <     |       |       | Bits fo | r LSU1 |       |       | >     |
| 15    | 14       | 13         | 12                 | 11          | 10    | 9     | 8     | 7     | 6     | 5     | 4       | 3      | 2     | 1     | 0     |
| ICC15 | ICC14    | ICC13      | ICC12              | ICC11       | ICC10 | ICC9  | ICC8  | ICC7  | ICC6  | ICC5  | ICC4    | ICC3   | ICC2  | ICC1  | ICC0  |
| W-0   | W-0      | W-0        | W-0                | W-0         | W-0   | W-0   | W-0   | W-0   | W-0   | W-0   | W-0     | W-0    | W-0   | W-0   | W-0   |
| LEGEN | D: W = V | Vrite only | ; - <i>n</i> = Val | lue after i | reset |       |       |       |       |       |         |        |       |       |       |

#### Table 74. LSU Interrupt Condition Clear Register (LSU\_ICCR) Field Descriptions

| Bit  | Field         | Value | Description                                                            |
|------|---------------|-------|------------------------------------------------------------------------|
| 31–0 | ICC <i>x</i>  | 0     | No effect                                                              |
|      | (x = 31 to 0) | 1     | Clear bit x of the LSU interrupt condition status register (LSU_ICSR). |



## 5.24 Error, Reset, and Special Event Interrupt Condition Status Register (ERR\_RST\_EVNT\_ICSR)

Each of the nonreserved bits in this register indicate the status of a particular interrupt condition in one or more of the SRIO ports. ERR\_RST\_EVNT\_ICSR is shown in Figure 85 and described in Table 75. For additional programming information, see Section 4.3.4.

#### Figure 85. Error, Reset, and Special Event Interrupt Condition Status Register (ERR\_RST\_EVNT\_ICSR) - Address Offset 0270h

| 31 |          |    |       |       |      |         |   |          |   |      | 17   | 16    |
|----|----------|----|-------|-------|------|---------|---|----------|---|------|------|-------|
|    |          |    |       |       |      | Reserve | d |          |   |      |      | ICS16 |
|    |          |    |       |       |      | R-0     |   |          |   |      |      | R-0   |
| 15 |          | 12 | 11    | 10    | 9    | 8       | 7 |          | 3 | 2    | 1    | 0     |
|    | Reserved |    | ICS11 | ICS10 | ICS9 | ICS8    |   | Reserved |   | ICS2 | ICS1 | ICS0  |
|    | R-0      |    | R-0   | R-0   | R-0  | R-0     |   | R-0      |   | R-0  | R-0  | R-0   |

LEGEND: R = Read only; W = Write only; -n = Value after reset

#### Table 75. Error, Reset, and Special Event Interrupt Condition Status Register (ERR\_RST\_EVNT\_ICSR) Field Descriptions

| Bit   | Field    | Value | Description                                                        |
|-------|----------|-------|--------------------------------------------------------------------|
| 31–17 | Reserved | 0     | These reserved bits return 0s when read.                           |
| 16    | ICS16    | 0     | Device reset interrupt not received from any port                  |
|       |          | 1     | Device reset interrupt received from any port                      |
| 15–12 | Reserved | 0     | These reserved bits return 0s when read.                           |
| 11    | ICS11    | 0     | Error not detected on port 3                                       |
|       |          | 1     | Error detected on port 3                                           |
| 10    | ICS10    | 0     | Error not detected on port 2                                       |
|       |          | 1     | Error detected on port 2                                           |
| 9     | ICS9     | 0     | Error not detected on port 1                                       |
|       |          | 1     | Error detected on port 1                                           |
| 8     | ICS8     | 0     | Error not detected on port 0                                       |
|       |          | 1     | Error detected on port 0                                           |
| 7–3   | Reserved | 0     | These reserved bits return 0s when read.                           |
| 2     | ICS2     | 0     | Logical layer error management event capture not detected          |
|       |          | 1     | Logical layer error management event capture detected              |
| 1     | ICS1     | 0     | Port-write-in request not received on any port                     |
|       |          | 1     | Port-write-in request received on any port                         |
| 0     | ICS0     | 0     | Multi-cast event control symbol interrupt not received on any port |
|       |          | 1     | Multi-cast event control symbol interrupt received on any port     |

# 5.25 Error, Reset, and Special Event Interrupt Condition Clear Register (ERR\_RST\_EVNT\_ICCR)

Each bit in this register is used to clear the corresponding status bit in ERR\_RST\_EVNT\_ICSR. The field of ERR\_RST\_EVNT\_ICCR are shown in Figure 86 and described in Table 76. For additional programming information, see Section 4.3.4.

#### Figure 86. Error, Reset, and Special Event Interrupt Condition Clear Register (ERR\_RST\_EVNT\_ICCR) - Address Offset 0278h

| 31 |          |    |       |       |      |         |   |          |   |      | 17   | 16    |
|----|----------|----|-------|-------|------|---------|---|----------|---|------|------|-------|
|    |          |    |       |       |      | Reserve | d |          |   |      |      | ICC16 |
|    |          |    |       |       |      | R-0     |   |          |   |      |      | W-0   |
| 15 |          | 12 | 11    | 10    | 9    | 8       | 7 |          | 3 | 2    | 1    | 0     |
|    | Reserved |    | ICC11 | ICC10 | ICC9 | ICC8    |   | Reserved |   | ICC2 | ICC1 | ICC0  |
|    | R-0      |    | W-0   | W-0   | W-0  | W-0     |   | R-0      |   | W-0  | W-0  | W-0   |

LEGEND: R = Read only; W = Write only; -n = Value after reset

#### Table 76. Error, Reset, and Special Event Interrupt Condition Clear Register (ERR\_RST\_EVNT\_ICCR) Field Descriptions

| Bit   | Field         | Value | Description                               |
|-------|---------------|-------|-------------------------------------------|
| 31–17 | Reserved      | 0     | These read-only bits return 0s when read. |
| 16    | ICC16         | 0     | No effect                                 |
|       |               | 1     | Clear bit 16 of ERR_RST_EVNT_ICSR.        |
| 15–12 | Reserved      | 0     | These read-only bits return 0s when read. |
| 11–8  | ICCx          | 0     | No effect                                 |
|       | (x = 11 to 8) | 1     | Clear bit x of ERR_RST_EVNT_ICSR.         |
| 7–3   | Reserved      | 0     | These read-only bits return 0s when read. |
| 2–0   | ICCy          | 0     | No effect                                 |
|       | (y = 2 to 0)  | 1     | Clear bit y of ERR_RST_EVNT_ICSR.         |



## 5.26 DOORBELLn Interrupt Condition Routing Registers (DOORBELLn\_ICRR and DOORBELLn\_ICRR2)

When doorbell packets are received by the SRIO peripheral, these ICRRs route doorbell interrupt requests from the associated doorbell ICSR to user-selected interrupt destinations. Each of the four doorbells can be mapped to these registers (see Table 77). The general field description in Table 78 applies to an ICRx field of either register. For additional programming information, see Section 4.4.1 and Section 2.3.6.

| Register        | Address Offset |  |
|-----------------|----------------|--|
| DOORBELL0_ICRR  | 0280h          |  |
| DOORBELL0_ICRR2 | 0284h          |  |
| DOORBELL1_ICRR  | 0290h          |  |
| DOORBELL1_ICRR2 | 0294h          |  |
| DOORBELL2_ICRR  | 02A0h          |  |
| DOORBELL2_ICRR2 | 02A4h          |  |
| DOORBELL3_ICRR  | 02B0h          |  |
| DOORBELL3_ICRR3 | 02B4h          |  |

#### Table 77. DOORBELLn\_ICRR Registers

#### Figure 87. Doorbell n Interrupt Condition Routing Registers

## Doorbell n Interrupt Condition Routing Register (DOORBELLn\_ICRR)

| 31                  | 28                                                   | 3 27          | 24                                            | 23                      | 20 | 19                                       | 16 |
|---------------------|------------------------------------------------------|---------------|-----------------------------------------------|-------------------------|----|------------------------------------------|----|
|                     | ICR7                                                 |               | ICR6                                          | ICR5                    |    | ICR4                                     |    |
|                     | R/W-0h                                               |               | R/W-0h                                        | R/W-0h                  |    | R/W-0h                                   |    |
| 15                  | 12                                                   | 2 11          | 8                                             | 7                       | 4  | 3                                        | 0  |
|                     | ICR3                                                 |               | ICR2                                          | ICR1                    |    | ICR0                                     |    |
|                     | R/W-0000                                             |               | R/W-0000                                      | R/W-0000                |    | R/W-0000                                 |    |
| Doorbe              |                                                      |               |                                               |                         |    | 10,0000                                  |    |
| Doorbe              | ell n Interrupt Condition                            |               |                                               |                         |    | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. |    |
| <b>Doorbe</b><br>31 | ell n Interrupt Condition                            |               | ster 2 (DOORBELLn_                            |                         | 20 | 19                                       | 16 |
|                     | ell n Interrupt Condition                            | Routing Regis | ster 2 (DOORBELLn_                            | ICRR2)                  | 20 |                                          | 16 |
|                     | ell n Interrupt Condition                            | Routing Regis | ster 2 (DOORBELLn_<br>24                      | ICRR2)<br>23            | 20 | 19                                       | 16 |
|                     | ell n Interrupt Condition<br>21<br>ICR15<br>R/W-0000 | Routing Regis | ster 2 (DOORBELLn_<br>24<br>ICR14<br>R/W-0000 | ICRR2)<br>23<br>ICR13   | 20 | 19<br>ICR12<br>R/W-0000                  | 16 |
| 31                  | ell n Interrupt Condition<br>21<br>ICR15<br>R/W-0000 | Routing Regis | ster 2 (DOORBELLn_<br>24<br>ICR14<br>R/W-0000 | 23<br>ICR13<br>R/W-0000 |    | 19<br>ICR12<br>R/W-0000                  |    |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 78. DOORBELLn Interrupt Condition Routing Register Field Descriptions

| Field                 | Value | Description                                                                                                                                                                                                                                                                                                        |
|-----------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ICRx<br>(x = 0 to 15) |       | Interrupt condition routing. Routes the interrupt request from doorbell <i>n</i> , bit x to one of eight interrupt destinations (INTDST0–INTDST7). For example, if ICS6 = 1 in DOORBELL2_ICSR and ICR6 = 0010b in DOORBELL2_ICRR, the interrupt request from doorbell 2, bit 6 is sent to interrupt destination 2. |
|                       | 0000b | INTDST0                                                                                                                                                                                                                                                                                                            |
|                       | 0001b | INTDST1                                                                                                                                                                                                                                                                                                            |
|                       | 0010b | INTDST2                                                                                                                                                                                                                                                                                                            |
|                       | 0011b | INTDST3                                                                                                                                                                                                                                                                                                            |
|                       | 0100b | INTDST4                                                                                                                                                                                                                                                                                                            |
|                       | 0101b | INTDST5                                                                                                                                                                                                                                                                                                            |
|                       | 0110b | INTDST6                                                                                                                                                                                                                                                                                                            |
|                       | 0111b | INTDST7                                                                                                                                                                                                                                                                                                            |
|                       | 1xxxb | Reserved                                                                                                                                                                                                                                                                                                           |

## 5.27 RX CPPI Interrupt Condition Routing Registers (RX\_CPPI\_ICRR and RX\_CPPI\_ICRR2)

Figure 88 and Table 79 summarize the ICRRs for the RXU. These registers route queue interrupts to interrupt destinations. For example, if ICS6 = 1 in RX\_CPPI\_ICSR and ICR6 = 0010b in RX\_CPPI\_ICRR, the interrupt request from RX buffer descriptor queue 6 is sent to interrupt destination 2. For additional programming see Section 4.4.1.1.

#### Figure 88. RX CPPI Interrupt Condition Routing Registers RX CPPI Interrupt Condition Routing Register (RX\_CPPI\_ICRR) (Address Offset 02C0h)

|    | •        |    | -  |          | , , |    | •        |    |          |    |
|----|----------|----|----|----------|-----|----|----------|----|----------|----|
| 31 |          | 28 | 27 |          | 24  | 23 |          | 20 | 19       | 16 |
|    | ICR7     |    |    | ICR6     |     |    | ICR5     |    | ICR4     |    |
|    | R/W-0000 |    |    | R/W-0000 |     |    | R/W-0000 |    | R/W-0000 |    |
| 15 |          | 12 | 11 |          | 8   | 7  |          | 4  | 3        | 0  |
|    | ICR3     |    |    | ICR2     |     |    | ICR1     |    | ICR0     |    |
|    | R/W-0000 |    |    | R/W-0000 |     |    | R/W-0000 |    | R/W-0000 |    |
|    |          |    |    |          |     |    |          |    |          |    |

#### RX CPPI Interrupt Condition Routing Register 2 (RX\_CPPI\_ICRR2) (Address Offset 02C4h)

| •        |                   |                           | , ,               |                                                                                                        |                                                                                                                                     |                                                                                                                                                                                                                                                           |
|----------|-------------------|---------------------------|-------------------|--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 28 27             | 7                         | 24 23             | 2                                                                                                      | 0 19                                                                                                                                | 16                                                                                                                                                                                                                                                        |
| ICR15    |                   | ICR14                     |                   | ICR13                                                                                                  | ICR12                                                                                                                               |                                                                                                                                                                                                                                                           |
| R/W-0000 |                   | R/W-0000                  |                   | R/W-0000                                                                                               | R/W-0000                                                                                                                            |                                                                                                                                                                                                                                                           |
|          | 12 1 <sup>.</sup> | 1                         | 87                |                                                                                                        | 4 3                                                                                                                                 | 0                                                                                                                                                                                                                                                         |
| ICR11    |                   | ICR10                     |                   | ICR9                                                                                                   | ICR8                                                                                                                                |                                                                                                                                                                                                                                                           |
|          |                   |                           |                   |                                                                                                        |                                                                                                                                     |                                                                                                                                                                                                                                                           |
|          | R/W-0000          | ICR15<br>R/W-0000<br>12 1 | R/W-0000 R/W-0000 | 28     27     24     23       ICR15     ICR14        R/W-0000     R/W-0000       12     11     8     7 | 28     27     24     23     24       ICR15     ICR14     ICR13       R/W-0000     R/W-0000     R/W-0000       12     11     8     7 | 28         27         24         23         20         19           ICR15         ICR14         ICR13         ICR12           R/W-0000         R/W-0000         R/W-0000         R/W-0000           12         11         8         7         4         3 |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 79. RX CPPI Interrupt Condition Routing Register Field Descriptions

| Field                                        | Value | Description                                                                                                                                                  |
|----------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\frac{\text{ICR}x}{(x = 0 \text{ to } 15)}$ |       | Interrupt condition routing. Routes the interrupt request from RX buffer descriptor queue <i>x</i> to one of eight interrupt destinations (INTDST0–INTDST7). |
|                                              | 0000b | INTDST0                                                                                                                                                      |
|                                              | 0001b | INTDST1                                                                                                                                                      |
|                                              | 0010b | INTDST2                                                                                                                                                      |
|                                              | 0011b | INTDST3                                                                                                                                                      |
|                                              | 0100b | INTDST4                                                                                                                                                      |
|                                              | 0101b | INTDST5                                                                                                                                                      |
|                                              | 0110b | INTDST6                                                                                                                                                      |
|                                              | 0111b | INTDST7                                                                                                                                                      |
|                                              | 1xxxb | Reserved                                                                                                                                                     |



#### SRIO Registers

### 5.28 TX CPPI Interrupt Condition Routing Registers (TX\_CPPI\_ICRR and TX\_CPPI\_ICRR2)

Figure 89 and Table 80 summarize the ICRRs for the TXU. These registers route queue interrupts to interrupt destinations. For example, if ICS6 = 1 in TX\_CPPI\_ICSR and ICR6 = 0011b in TX\_CPPI\_ICRR, the interrupt request from TX buffer descriptor queue 6 is sent to interrupt destination 3. For additional programming see Section 4.4.1.1.

#### Figure 89. TX CPPI Interrupt Condition Routing Registers TX CPPI Interrupt Condition Routing Register (TX\_CPPI\_ICRR) (Address Offset 02D0h)

|    | •        | 00(      | - , , | ,        |          |    |
|----|----------|----------|-------|----------|----------|----|
| 31 | 2        | 28 27    | 24 23 | 20       | 19       | 16 |
|    | ICR7     | ICR6     |       | ICR5     | ICR4     |    |
|    | R/W-0000 | R/W-0000 | )     | R/W-0000 | R/W-0000 |    |
| 15 | 1        | 12 11    | 87    | 4        | 3        | 0  |
|    | ICR3     | ICR2     |       | ICR1     | ICR0     |    |
|    | R/W-0000 | R/W-0000 |       | R/W-0000 | R/W-0000 |    |

#### TX CPPI Interrupt Condition Routing Register 2 (TX\_CPPI\_ICRR2) (Address Offset 02D4h)

|    | -        |    | -  |          |    | -  |          |    |          |    |
|----|----------|----|----|----------|----|----|----------|----|----------|----|
| 31 |          | 28 | 27 |          | 24 | 23 |          | 20 | 19       | 16 |
|    | ICR15    |    |    | ICR14    |    |    | ICR13    |    | ICR12    |    |
|    | R/W-0000 |    |    | R/W-0000 |    |    | R/W-0000 |    | R/W-0000 |    |
| 15 |          | 12 | 11 |          | 8  | 7  |          | 4  | 3        | 0  |
|    | ICR11    |    |    | ICR10    |    |    | ICR9     |    | ICR8     |    |
|    | R/W-0000 |    |    | R/W-0000 |    |    | R/W-0000 |    | R/W-0000 |    |
|    |          |    |    |          |    |    |          |    |          |    |

LEGEND: R/W = Read/Write; -n = Value after reset

#### Table 80. TX CPPI Interrupt Condition Routing Register Field Descriptions

| Field                                        | Value | Description                                                                                                                                                  |
|----------------------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\frac{\text{ICR}x}{(x = 0 \text{ to } 15)}$ |       | Interrupt condition routing. Routes the interrupt request from TX buffer descriptor queue <i>x</i> to one of eight interrupt destinations (INTDST0–INTDST7). |
|                                              | 0000b | INTDST0                                                                                                                                                      |
|                                              | 0001b | INTDST1                                                                                                                                                      |
|                                              | 0010b | INTDST2                                                                                                                                                      |
|                                              | 0011b | INTDST3                                                                                                                                                      |
|                                              | 0100b | INTDST4                                                                                                                                                      |
|                                              | 0101b | INTDST5                                                                                                                                                      |
|                                              | 0110b | INTDST6                                                                                                                                                      |
|                                              | 0111b | INTDST7                                                                                                                                                      |
|                                              | 1xxxb | Reserved                                                                                                                                                     |

## 5.29 LSU Interrupt Condition Routing Registers (LSU\_ICRR0–LSU\_ICRR3)

Figure 90 shows the ICRRs for the LSU interrupt requests, and Table 81 shows the general description for an ICRx field in any of the four registers. These registers route LSU interrupt requests from LSU\_ICSR to interrupt destinations. For example, if ICS4 = 1 in LSU\_ICSR and ICR4 = 0000b in LSU\_ICRR0, LSU1 has generated a transaction-timeout interrupt request, and that request is routed to interrupt destination 0. For additional programming see Section 4.4.1.2.

| 31                              |                                                              | 28                        | 27                                                                                                                                                                                                      | 24                       | 23                         |                                                                         | 20 | 19 |                                        | 16                 |
|---------------------------------|--------------------------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------------------------|-------------------------------------------------------------------------|----|----|----------------------------------------|--------------------|
|                                 | ICR7                                                         |                           | ICR6                                                                                                                                                                                                    |                          |                            | ICR5                                                                    |    |    | ICR4                                   |                    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                                |                          |                            | R/W-0000                                                                |    |    | R/W-0000                               |                    |
| 15                              |                                                              | 12                        | 11                                                                                                                                                                                                      | 8                        | 7                          |                                                                         | 4  | 3  |                                        | 0                  |
|                                 | ICR3                                                         |                           | ICR2                                                                                                                                                                                                    |                          |                            | ICR1                                                                    |    |    | ICR0                                   |                    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                                |                          | r.                         | R/W-0000                                                                |    |    | R/W-0000                               |                    |
| LSU li                          | nterrupt Condition                                           | Routing                   | Register 1 (LSU_ICRR1)                                                                                                                                                                                  | (Addres                  | s Offset                   | t 02E4h)                                                                |    |    |                                        |                    |
| 31                              |                                                              | 28                        | 27                                                                                                                                                                                                      | 24                       | 23                         |                                                                         | 20 | 19 |                                        | 16                 |
|                                 | ICR15                                                        |                           | ICR14                                                                                                                                                                                                   |                          |                            | ICR13                                                                   |    |    | ICR12                                  |                    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                                |                          |                            | R/W-0000                                                                |    |    | R/W-0000                               |                    |
| 15                              |                                                              | 12                        | 11                                                                                                                                                                                                      | 8                        | 7                          |                                                                         | 4  | 3  |                                        | 0                  |
|                                 | ICR11                                                        |                           | ICR10                                                                                                                                                                                                   |                          |                            | ICR9                                                                    |    |    | ICR8                                   |                    |
|                                 | R/W-0000                                                     |                           | R/W-0000                                                                                                                                                                                                |                          |                            | R/W-0000                                                                |    |    | R/W-0000                               |                    |
|                                 |                                                              |                           |                                                                                                                                                                                                         |                          |                            | 1011 0000                                                               |    |    | 10/00/0000                             |                    |
| LSU li                          | nterrupt Condition                                           | Routing                   | Register 2 (LSU_ICRR2)                                                                                                                                                                                  | (Addres                  | s Offset                   |                                                                         |    |    | 10.0000                                |                    |
| <b>LSU lı</b><br>31             | nterrupt Condition                                           | Routing<br>28             | Register 2 (LSU_ICRR2)                                                                                                                                                                                  | •                        | s Offset                   |                                                                         | 20 | 19 |                                        | 16                 |
|                                 | ICR23                                                        | -                         | Register 2 (LSU_ICRR2)                                                                                                                                                                                  | •                        |                            |                                                                         | 20 | 19 | ICR20                                  | 16                 |
|                                 | -                                                            | -                         | Pregister 2 (LSU_ICRR2)                                                                                                                                                                                 | •                        |                            | t 02E8h)                                                                | 20 | 19 |                                        | 16                 |
|                                 | ICR23                                                        | -                         | Register 2 (LSU_ICRR2)<br>27<br>ICR22<br>R/W-0000                                                                                                                                                       | 24                       |                            | t <b>02E8h)</b><br>ICR21                                                | 20 |    | ICR20                                  |                    |
| 31                              | ICR23                                                        | 28                        | Register 2 (LSU_ICRR2)<br>27<br>ICR22<br>R/W-0000                                                                                                                                                       | 24                       | 23                         | t <b>02E8h)</b><br>ICR21                                                |    |    | ICR20                                  |                    |
| 31                              | ICR23<br>R/W-0000                                            | 28                        | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11                                                                                                                     | 24                       | 23                         | t <b>02E8h)</b><br>ICR21<br>R/W-0000                                    |    |    | ICR20<br>R/W-0000                      |                    |
| 31                              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000                       | 12                        | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11           ICR18                                                                                                     | 8                        | 23<br>7                    | t 02E8h)<br>ICR21<br>R/W-0000<br>ICR17<br>R/W-0000                      |    |    | ICR20<br>R/W-0000<br>ICR16             |                    |
| 31                              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000                       | 12                        | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11           ICR18           R/W-0000           HCR18           R/W-0000           R/W-0000                            | 24<br>8<br>(Addres       | 23<br>7                    | t 02E8h)<br>ICR21<br>R/W-0000<br>ICR17<br>R/W-0000                      |    | 3  | ICR20<br>R/W-0000<br>ICR16             | 0                  |
| 31<br>15<br>LSU II              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000                       | 28<br>12<br>Routing       | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11           ICR18           R/W-0000           HCR18           R/W-0000           R/W-0000                            | 24<br>8<br>(Addres       | 23<br>7<br>ss Offset       | t 02E8h)<br>ICR21<br>R/W-0000<br>ICR17<br>R/W-0000                      | 4  | 3  | ICR20<br>R/W-0000<br>ICR16             | 0                  |
| 31<br>15<br>LSU II              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000<br>nterrupt Condition | 28<br>12<br>Routing       | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11           ICR18           R/W-0000           12           ICR18           R/W-0000           27                     | 24<br>8<br>(Addres       | 23<br>7<br>ss Offset       | t 02E8h)<br>ICR21<br>R/W-0000<br>ICR17<br>R/W-0000<br>t 02ECh)          | 4  | 3  | ICR20<br>R/W-0000<br>ICR16<br>R/W-0000 | 0                  |
| 31<br>15<br>LSU II              | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000<br>nterrupt Condition | 28<br>12<br>Routing       | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11           ICR18           R/W-0000           Pagister 3 (LSU_ICRR3)           27           ICR30           R/W-0000 | 24<br>8<br>(Addres<br>24 | 23<br>7<br>ss Offset       | t 02E8h)<br>ICR21<br>R/W-0000<br>ICR17<br>R/W-0000<br>t 02ECh)<br>ICR29 | 4  | 3  | ICR20<br>R/W-0000<br>ICR16<br>R/W-0000 | 0                  |
| 31<br>15<br><b>LSU lı</b><br>31 | ICR23<br>R/W-0000<br>ICR19<br>R/W-0000<br>nterrupt Condition | 28<br>12<br>Routing<br>28 | Register 2 (LSU_ICRR2)           27           ICR22           R/W-0000           11           ICR18           R/W-0000           Pagister 3 (LSU_ICRR3)           27           ICR30           R/W-0000 | 24<br>8<br>(Addres<br>24 | 23<br>7<br>ss Offset<br>23 | t 02E8h)<br>ICR21<br>R/W-0000<br>ICR17<br>R/W-0000<br>t 02ECh)<br>ICR29 | 4  | 3  | ICR20<br>R/W-0000<br>ICR16<br>R/W-0000 | 16<br>0<br>16<br>0 |

LEGEND: R/W = Read/Write; -*n* = Value after reset



#### SRIO Registers

| Field                         | Value | Description                                                                                                                                                                                                                                        |
|-------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ICR <i>x</i><br>(x = 0 to 31) |       | Interrupt condition routing. Routes the associated LSU interrupt request to one of eight interrupt destinations (INTDST0–INTDST7). Bits ICR0–ICR7 are for LSU1; bits ICR8–ICR15, for LSU2; bits ICR16–ICR23, for LSU3; bits ICR24–ICR31, for LSU4. |
|                               | 0000b | INTDST0                                                                                                                                                                                                                                            |
|                               | 0001b | INTDST1                                                                                                                                                                                                                                            |
|                               | 0010b | INTDST2                                                                                                                                                                                                                                            |
|                               | 0011b | INTDST3                                                                                                                                                                                                                                            |
|                               | 0100b | INTDST4                                                                                                                                                                                                                                            |
|                               | 0101b | INTDST5                                                                                                                                                                                                                                            |
|                               | 0110b | INTDST6                                                                                                                                                                                                                                            |
|                               | 0111b | INTDST7                                                                                                                                                                                                                                            |
|                               | 1xxxb | Reserved                                                                                                                                                                                                                                           |

#### Table 81. LSU Interrupt Condition Routing Register Field Descriptions

#### 5.30 Error, Reset, and Special Event Interrupt Condition Routing Registers (ERR\_RST\_EVNT\_ICRR, ERR\_RST\_EVNT\_ICRR2, and ERR\_RST\_EVNT\_ICRR3)

The ICRRs shown in Figure 91 route port interrupt requests from ERR RST EVNT ICSR to interrupt destinations. For example, if ICS8 = 1 in ERR\_RST\_EVNT\_ICSR and ICR8 = 0001b in ERR\_RST\_EVNT\_ICRR2, port 0 has generated an error interrupt request, and that request is routed to interrupt destination 1. Table 82 gives a general description for an ICRx field in any of the three registers. For additional programming see Section 4.4.1.3.

#### Figure 91. Error, Reset, and Special Event Interrupt Condition Routing Registers Error, Reset, and Special Event ICRR (ERR\_RST\_EVNT\_ICRR) (Address Offset 02F0h)

|                    |                 |                         | Reserved                                   |               |     |          |    |
|--------------------|-----------------|-------------------------|--------------------------------------------|---------------|-----|----------|----|
|                    |                 |                         | R-0                                        |               |     |          |    |
|                    | 12              | 11                      | 8 7                                        |               | 4 3 |          | 0  |
| Reserv             | ved             | ICR2                    |                                            | ICR1          |     | ICR0     |    |
| R-0                |                 | R/W-0000                |                                            | R/W-0000      |     | R/W-0000 |    |
| Error, Reset, & Si | pecial Event IC | RR 2 (ERR_RST_EVNT_ICRF | ₹2) (Address (                             | Offset 02F4h) |     |          |    |
| 31                 |                 |                         | (1) (7) (7) (7) (7) (7) (7) (7) (7) (7) (7 |               |     |          | 16 |
|                    |                 |                         | Reserved                                   |               |     |          |    |
|                    |                 | -                       | R-0                                        |               |     |          |    |
| 15                 | 12              | 11                      | 87                                         |               | 4 3 |          | 0  |
|                    | 4               | ICR10                   |                                            | ICR9          |     | ICR8     |    |
| ICR1               | 1               |                         |                                            |               |     |          |    |
| ICR1<br>R/W-00     |                 | R/W-0000                |                                            | R/W-0000      |     | R/W-0000 |    |
| R/W-00             | 000             | R/W-0000                | RR3) (Addres                               |               |     | R/W-0000 |    |
| R/W-00             | 000             |                         | RR3) (Addres                               |               |     | R/W-0000 |    |

| K-U      |          |
|----------|----------|
| 4        | 3 0      |
| Reserved | ICR16    |
| R-0      | R/W-0000 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 82. Error, Reset, and Special Event Interrupt Condition Routing Register Field Descriptions

| Field                                         | Value | Description                                                                                                                         |
|-----------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| ICR <i>x</i><br>(x = 0 to 2, 8 to 11, and 16) |       | Interrupt condition routing. Routes the associated port interrupt request to one of eight interrupt destinations (INTDST0–INTDST7). |
|                                               | 0000b | INTDST0                                                                                                                             |
|                                               | 0001b | INTDST1                                                                                                                             |
|                                               | 0010b | INTDST2                                                                                                                             |
|                                               | 0011b | INTDST3                                                                                                                             |
|                                               | 0100b | INTDST4                                                                                                                             |
|                                               | 0101b | INTDST5                                                                                                                             |
|                                               | 0110b | INTDST6                                                                                                                             |
|                                               | 0111b | INTDST7                                                                                                                             |
|                                               | 1xxxb | Reserved                                                                                                                            |



#### 5.31 Interrupt Status Decode Register (INTDSTn\_DECODE)

There are eight of these registers, one for each interrupt destination (see Table 83). This type of register is shown in Figure 92 and described in Table 84. Interrupt sources are mapped to an interrupt decode register only if the ICRRs routes the interrupt source to the corresponding physical interrupt. Each status decode bit is a logical OR of multiple interrupt sources that are mapped to the same bit. For additional programming see Section 4.5.

#### Table 83. INTDSTn\_DECODE Registers and the Associated Interrupt Destinations

| Register       | Address Offset | Associated Interrupt<br>Destination |
|----------------|----------------|-------------------------------------|
| INTDST0_DECODE | 0300h          | INTDST0                             |
| INTDST1_DECODE | 0304h          | INTDST1                             |
| INTDST2_DECODE | 0308h          | INTDST2                             |
| INTDST3_DECODE | 030Ch          | INTDST3                             |
| INTDST4_DECODE | 0310h          | INTDST4                             |
| INTDST5_DECODE | 0314h          | INTDST5                             |
| INTDST6_DECODE | 0318h          | INTDST6                             |
| INTDST7_DECODE | 031Ch          | INTDST7                             |

#### Figure 92. Interrupt Status Decode Register (INTDSTn\_DECODE)

| 31     | 30              | 29      | 28       | 27        | 26        | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|--------|-----------------|---------|----------|-----------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| ISD31  | ISD30           | ISD29   | ISD28    | ISD27     | ISD26     | ISD25 | ISD24 | ISD23 | ISD22 | ISD21 | ISD20 | ISD19 | ISD18 | ISD17 | ISD16 |
| R-0    | R-0             | R-0     | R-0      | R-0       | R-0       | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   |
| 15     | 14              | 13      | 12       | 11        | 10        | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| ISD15  | ISD14           | ISD13   | ISD12    | ISD11     | ISD10     | ISD9  | ISD8  | ISD7  | ISD6  | ISD5  | ISD4  | ISD3  | ISD2  | ISD1  | ISD0  |
| R-0    | R-0             | R-0     | R-0      | R-0       | R-0       | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   | R-0   |
| I EGEN | $D \cdot R = R$ | ead W = | Write -r | ) = Value | after res | et    |       |       |       |       |       |       |       |       |       |

LEGEND: R = Read, W = Write, -n = Value after reset

#### Table 84. Interrupt Status Decode Register (INTDSTn\_DECODE) Field Descriptions

| Bit | Field | Value | Description                                                              |
|-----|-------|-------|--------------------------------------------------------------------------|
| 31  | ISD31 | 0     | No interrupt request routed to this bit.                                 |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                  |
|     |       |       | An LSU (check LSU_ICSR)                                                  |
|     |       |       | <ul> <li>TX buffer descriptor queue 0 (bit 0 of TX_CPPI_ICSR)</li> </ul> |
|     |       |       | RX buffer descriptor queue 0 (bit 0 of RX_CPPI_ICSR)                     |
| 30  | ISD30 | 0     | No interrupt request routed to this bit.                                 |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                  |
|     |       |       | A port (check ERR_RST_EVNT_ICSR)                                         |
|     |       |       | • TX buffer descriptor queue 1 (bit 1 of TX_CPPI_ICSR)                   |
|     |       |       | RX buffer descriptor queue 1 (bit 1 of RX_CPPI_ICSR)                     |
| 29  | ISD29 | 0     | No interrupt request routed to this bit.                                 |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                  |
|     |       |       | • TX buffer descriptor queue 2 (bit 2 of TX_CPPI_ICSR)                   |
|     |       |       | RX buffer descriptor queue 2 (bit 2 of RX_CPPI_ICSR)                     |
| 28  | ISD28 | 0     | No interrupt request routed to this bit.                                 |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                  |
|     |       |       | • TX buffer descriptor queue 3 (bit 3 of TX_CPPI_ICSR)                   |
|     |       |       | RX buffer descriptor queue 3 (bit 3 of RX_CPPI_ICSR)                     |

### Table 84. Interrupt Status Decode Register (INTDSTn\_DECODE) Field Descriptions (continued)

| Bit | Field  | Value | Description                                                                |
|-----|--------|-------|----------------------------------------------------------------------------|
| 27  | ISD27  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | • TX buffer descriptor queue 4 (bit 4 of TX_CPPI_ICSR)                     |
|     |        |       | RX buffer descriptor queue 4 (bit 4 of RX_CPPI_ICSR)                       |
| 26  | ISD26  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 5 (bit 5 of TX_CPPI_ICSR)                       |
|     |        |       | RX buffer descriptor queue 5 (bit 5 of RX_CPPI_ICSR)                       |
| 25  | ISD25  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 6 (bit 6 of TX_CPPI_ICSR)                       |
|     |        |       | RX buffer descriptor queue 6 (bit 6 of RX_CPPI_ICSR)                       |
| 24  | ISD24  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 7 (bit 7 of TX_CPPI_ICSR)                       |
|     |        |       | RX buffer descriptor queue 7 (bit 7 of RX_CPPI_ICSR)                       |
| 23  | ISD23  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 8 (bit 8 of TX_CPPI_ICSR)                       |
|     |        |       | RX buffer descriptor queue 8 (bit 8 of RX_CPPI_ICSR)                       |
| 22  | ISD22  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 9 (bit 9 of TX_CPPI_ICSR)                       |
|     |        |       | RX buffer descriptor queue 9 (bit 9 of RX_CPPI_ICSR)                       |
| 21  | ISD21  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | <ul> <li>TX buffer descriptor queue 10 (bit 10 of TX_CPPI_ICSR)</li> </ul> |
|     |        |       | RX buffer descriptor queue 10 (bit 10 of RX_CPPI_ICSR)                     |
| 20  | ISD20  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 11 (bit 11 of TX_CPPI_ICSR)                     |
|     |        |       | RX buffer descriptor queue 11 (bit 11 of RX_CPPI_ICSR)                     |
| 19  | ISD19  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 12 (bit 12 of TX_CPPI_ICSR)                     |
|     |        | -     | RX buffer descriptor queue 12 (bit 12 of RX_CPPI_ICSR)                     |
| 18  | ISD18  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 13 (bit 13 of TX_CPPI_ICSR)                     |
|     | 100.17 | -     | RX buffer descriptor queue 13 (bit 13 of RX_CPPI_ICSR)                     |
| 17  | ISD17  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 14 (bit 14 of TX_CPPI_ICSR)                     |
|     |        | -     | RX buffer descriptor queue 14 (bit 14 of RX_CPPI_ICSR)                     |
| 16  | ISD16  | 0     | No interrupt request routed to this bit.                                   |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                    |
|     |        |       | TX buffer descriptor queue 15 (bit 15 of TX_CPPI_ICSR)                     |
|     |        |       | RX buffer descriptor queue 15 (bit 15 of RX_CPPI_ICSR)                     |



## Table 84. Interrupt Status Decode Register (INTDST*n*\_DECODE) Field Descriptions (continued)

| Bit | Field  | Value | Description                                                                                                              |
|-----|--------|-------|--------------------------------------------------------------------------------------------------------------------------|
| 15  | ISD15  | 0     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 15 (bit 15 of DOORBELL0_ICSR)                                                                            |
|     |        |       | Doorbell 1, bit 15 (bit 15 of DOORBELL1_ICSR)                                                                            |
|     |        |       | Doorbell 2, bit 15 (bit 15 of DOORBELL2_ICSR)                                                                            |
|     |        |       | Doorbell 3, bit 15 (bit 15 of DOORBELL3_ICSR)                                                                            |
| 14  | ISD14  | 0     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 14 (bit 14 of DOORBELL0_ICSR)                                                                            |
|     |        |       | Doorbell 1, bit 14 (bit 14 of DOORBELL1_ICSR)                                                                            |
|     |        |       | Doorbell 2, bit 14 (bit 14 of DOORBELL2_ICSR)                                                                            |
| 40  | 100.40 |       | Doorbell 3, bit 14 (bit 14 of DOORBELL3_ICSR)                                                                            |
| 13  | ISD13  | 0     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 13 (bit 13 of DOORBELL0_ICSR)                                                                            |
|     |        |       | <ul> <li>Doorbell 1, bit 13 (bit 13 of DOORBELL1_ICSR)</li> <li>Doorbell 2, bit 13 (bit 13 of DOORBELL2_ICSR)</li> </ul> |
|     |        |       | <ul> <li>Doorbell 2, bit 13 (bit 13 of DOORBELL2_ICSR)</li> <li>Doorbell 3, bit 13 (bit 13 of DOORBELL3_ICSR)</li> </ul> |
| 12  | ISD12  | 0     | No interrupt request routed to this bit.                                                                                 |
| 12  | 10012  | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 12 (bit 12 of DOORBELL0 ICSR)                                                                            |
|     |        |       | Doorbell 1, bit 12 (bit 12 of DOORBELL1_ICSR)                                                                            |
|     |        |       | Doorbell 2, bit 12 (bit 12 of DOORBELL2_ICSR)                                                                            |
|     |        |       | Doorbell 3, bit 12 (bit 12 of DOORBELL3_ICSR)                                                                            |
| 11  | ISD11  | 0     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 11 (bit 11 of DOORBELL0_ICSR)                                                                            |
|     |        |       | Doorbell 1, bit 11 (bit 11 of DOORBELL1_ICSR)                                                                            |
|     |        |       | Doorbell 2, bit 11 (bit 11 of DOORBELL2_ICSR)                                                                            |
|     |        |       | Doorbell 3, bit 11 (bit 11 of DOORBELL3_ICSR)                                                                            |
| 10  | ISD10  | 0     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 10 (bit 10 of DOORBELL0_ICSR)                                                                            |
|     |        |       | Doorbell 1, bit 10 (bit 10 of DOORBELL1_ICSR)                                                                            |
|     |        |       | Doorbell 2, bit 10 (bit 10 of DOORBELL2_ICSR)                                                                            |
|     |        |       | Doorbell 3, bit 10 (bit 10 of DOORBELL3_ICSR)                                                                            |
| 9   | ISD9   | 0     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 9 (bit 9 of DOORBELL0_ICSR)                                                                              |
|     |        |       | Doorbell 1, bit 9 (bit 9 of DOORBELL1_ICSR)                                                                              |
|     |        |       | Doorbell 2, bit 9 (bit 9 of DOORBELL2_ICSR)                                                                              |
| 8   | ISD8   | 0     | Doorbell 3, bit 9 (bit 9 of DOORBELL3_ICSR)                                                                              |
| ð   | 1900   | -     | No interrupt request routed to this bit.                                                                                 |
|     |        | 1     | Interrupt request detected. Possible interrupt sources:                                                                  |
|     |        |       | Doorbell 0, bit 8 (bit 8 of DOORBELL0_ICSR)                                                                              |
|     |        |       | Doorbell 1, bit 8 (bit 8 of DOORBELL1_ICSR)                                                                              |
|     |        |       | <ul> <li>Doorbell 2, bit 8 (bit 8 of DOORBELL2_ICSR)</li> <li>Doorbell 3, bit 8 (bit 8 of DOORBELL3_ICSR)</li> </ul>     |
|     |        |       |                                                                                                                          |

### Table 84. Interrupt Status Decode Register (INTDSTn\_DECODE) Field Descriptions (continued)

| Bit | Field | Value | Description                                                                                                          |
|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------|
| 7   | ISD7  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | Doorbell 0, bit 7 (bit 7 of DOORBELL0_ICSR)                                                                          |
|     |       |       | Doorbell 1, bit 7 (bit 7 of DOORBELL1_ICSR)                                                                          |
|     |       |       | Doorbell 2, bit 7 (bit 7 of DOORBELL2_ICSR)                                                                          |
|     |       |       | Doorbell 3, bit 7 (bit 7 of DOORBELL3_ICSR)                                                                          |
| 6   | ISD6  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | <ul> <li>Doorbell 0, bit 6 (bit 6 of DOORBELL0_ICSR)</li> </ul>                                                      |
|     |       |       | <ul> <li>Doorbell 1, bit 6 (bit 6 of DOORBELL1_ICSR)</li> </ul>                                                      |
|     |       |       | Doorbell 2, bit 6 (bit 6 of DOORBELL2_ICSR)                                                                          |
|     |       |       | Doorbell 3, bit 6 (bit 6 of DOORBELL3_ICSR)                                                                          |
| 5   | ISD5  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | <ul> <li>Doorbell 0, bit 5 (bit 5 of DOORBELL0_ICSR)</li> </ul>                                                      |
|     |       |       | Doorbell 1, bit 5 (bit 5 of DOORBELL1_ICSR)                                                                          |
|     |       |       | Doorbell 2, bit 5 (bit 5 of DOORBELL2_ICSR)                                                                          |
|     | 1004  |       | Doorbell 3, bit 5 (bit 5 of DOORBELL3_ICSR)                                                                          |
| 4   | ISD4  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | Doorbell 0, bit 4 (bit 4 of DOORBELL0_ICSR)                                                                          |
|     |       |       | Doorbell 1, bit 4 (bit 4 of DOORBELL1_ICSR)                                                                          |
|     |       |       | <ul> <li>Doorbell 2, bit 4 (bit 4 of DOORBELL2_ICSR)</li> <li>Doorbell 3, bit 4 (bit 4 of DOORBELL3_ICSR)</li> </ul> |
| 3   | ISD3  | 0     | No interrupt request routed to this bit.                                                                             |
| -   |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | Doorbell 0, bit 3 (bit 3 of DOORBELL0_ICSR)                                                                          |
|     |       |       | Doorbell 1, bit 3 (bit 3 of DOORBELL1_ICSR)                                                                          |
|     |       |       | Doorbell 2, bit 3 (bit 3 of DOORBELL2_ICSR)                                                                          |
|     |       |       | Doorbell 3, bit 3 (bit 3 of DOORBELL3_ICSR)                                                                          |
| 2   | ISD2  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | <ul> <li>Doorbell 0, bit 2 (bit 2 of DOORBELL0_ICSR)</li> </ul>                                                      |
|     |       |       | <ul> <li>Doorbell 1, bit 2 (bit 2 of DOORBELL1_ICSR)</li> </ul>                                                      |
|     |       |       | Doorbell 2, bit 2 (bit 2 of DOORBELL2_ICSR)                                                                          |
|     |       |       | Doorbell 3, bit 2 (bit 2 of DOORBELL3_ICSR)                                                                          |
| 1   | ISD1  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | Doorbell 0, bit 1 (bit 1 of DOORBELL0_ICSR)                                                                          |
|     |       |       | Doorbell 1, bit 1 (bit 1 of DOORBELL1_ICSR)                                                                          |
|     |       |       | Doorbell 2, bit 1 (bit 1 of DOORBELL2_ICSR)                                                                          |
| 6   | 1000  |       | Doorbell 3, bit 1 (bit 1 of DOORBELL3_ICSR)                                                                          |
| 0   | ISD0  | 0     | No interrupt request routed to this bit.                                                                             |
|     |       | 1     | Interrupt request detected. Possible interrupt sources:                                                              |
|     |       |       | Doorbell 0, bit 0 (bit 0 of DOORBELL0_ICSR)                                                                          |
|     |       |       | Doorbell 1, bit 0 (bit 0 of DOORBELL1_ICSR)                                                                          |
|     |       |       | Doorbell 2, bit 0 (bit 0 of DOORBELL2_ICSR)                                                                          |
|     |       |       | Doorbell 3, bit 0 (bit 0 of DOORBELL3_ICSR)                                                                          |



n

21

## 5.32 INTDSTn Interrupt Rate Control Register (INTDSTn\_RATE\_CNTL)

There are eight interrupt rate control registers, one for each interrupt destination (see Table 85). Figure 93 and Table 86 provide a general description for an interrupt rate control register. These registers are used to set the rate at which an interrupt can be generated for each interrupt destination. A write to one of the registers reloads a counter and immediately starts the counter decrementing. When the counter value reaches 0 (after counting down or after a CPU write of 0), the interrupt logic generates a single interrupt pulse if any bits in the corresponding ICSR are set (or become set after the zero count is reached). For additional programming see Section 4.7.

| Register          | Address Offset | Associated Interrupt<br>Destination |
|-------------------|----------------|-------------------------------------|
| INTDST0_RATE_CNTL | 0320h          | INTDST0                             |
| INTDST1_RATE_CNTL | 0324h          | INTDST1                             |
| INTDST2_RATE_CNTL | 0328h          | INTDST2                             |
| INTDST3_RATE_CNTL | 032Ch          | INTDST3                             |
| INTDST4_RATE_CNTL | 0330h          | INTDST4                             |
| INTDST5_RATE_CNTL | 0334h          | INTDST5                             |
| INTDST6_RATE_CNTL | 0338h          | INTDST6                             |
| INTDST7_RATE_CNTL | 033Ch          | INTDST7                             |
|                   |                |                                     |

## Table 85. INTDST*n*\_RATE\_CNTL Registers and the Associated Interrupt Destinations

#### Figure 93. INTDSTn Interrupt Rate Control Register (INTDSTn\_RATE\_CNTL)

| 31 |                  | 0 |
|----|------------------|---|
|    | COUNT_DOWN_VALUE |   |
|    | R/W-0000000h     |   |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 86. INTDSTn Interrupt Rate Control Register (INTDSTn\_RATE\_CNTL) Field Descriptions

| Bit  | Field            | Value                       | Description                                                                                                                                                    |
|------|------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | COUNT_DOWN_VALUE | 00000000h<br>to<br>FFFFFFFh | The value written to this field is immediately transferred to the interrupt rate counter, which starts counting down (or causes an interrupt if 0 is written). |

-

## 5.33 LSUn Control Register 0 (LSUn\_REG0)

\_ . . . . . . . . . . . . .

There are four of these registers, one for each LSU (see Table 87). The general description for an LSU control register 0 is shown in Figure 94 and described in Table 88. For additional programming see Section 2.3.3.

. . .

-

. . . . .

| Table 87. LSU <i>n_</i> REG0 Registers and the Associated LSUs |                |                |  |  |  |
|----------------------------------------------------------------|----------------|----------------|--|--|--|
| Register                                                       | Address Offset | Associated LSU |  |  |  |
| LSU1_REG0                                                      | 0400h          | LSU1           |  |  |  |
| LSU2_REG0                                                      | 0420h          | LSU2           |  |  |  |
| LSU3_REG0                                                      | 0440h          | LSU3           |  |  |  |
| LSU4_REG0                                                      | 0460h          | LSU4           |  |  |  |

## Figure 94. LSU*n* Control Register 0 (LSU*n*\_REG0)

| 31 | 0           | ) |
|----|-------------|---|
|    | ADDRESS_MSB |   |
|    | R/W-00h     | _ |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 88. LSUn Control Register 0 (LSUn\_REG0) Field Descriptions

| Bit  | Field       | Value                       | Description                                                                          |
|------|-------------|-----------------------------|--------------------------------------------------------------------------------------|
| 31–0 | ADDRESS_MSB | 00000000h<br>to<br>FFFFFFFh | 32-bit most significant bits of an extended address specified through LSU <i>n</i> . |



## 5.34 LSUn Control Register 1 (LSUn\_REG1)

There are four of these registers, one for each LSU (see ). This register's content is shown in Figure 95 and described in Table 90. For additional programming see Section 2.3.3.

| Register  | Address Offset | Associated LSU |
|-----------|----------------|----------------|
| LSU1_REG1 | 0404h          | LSU1           |
| LSU2_REG1 | 0424h          | LSU2           |
| LSU3_REG1 | 0444h          | LSU3           |
| LSU4_REG1 | 0464h          | LSU4           |

#### Figure 95. LSUn Control Register 1 (LSUn\_REG1)

31

0
ADDRESS\_LSB/CONFIG\_OFFSET
R/W-0000000h

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 90. LSUn Control Register 1 (LSUn\_REG1) Field Descriptions

| Bit  | Field                     | Value                        | Description                                                                                                                                                                                                                                                               |
|------|---------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | ADDRESS_LSB/CONFIG_OFFSET | 00000000h<br>to<br>FFFFFFFh  | For packet types 2, 5, and 6:<br>The 32-bit destination address or the 32 least significant bits of<br>an extended destination address. This value is used in<br>conjunction with BYTE_COUNT to create a 64-bit aligned<br>RapidIO packet header address.                 |
|      |                           |                              | For packet type 8 (maintenance packet):                                                                                                                                                                                                                                   |
|      |                           | 00000000h<br>to<br>00FFFFFFh | The right-aligned 24-bit register configuration offset. This value is used in conjunction with BYTE_COUNT to create a 64-bit aligned RapidIO packet header Config_offset value. The 2 LSBs of this field must be 0s because the smallest configuration access is 4 bytes. |

## 5.35 LSUn Control Register 2 (LSUn\_REG2)

There are four of these registers, one for each LSU (see Table 91). LSU*n*\_REG2 is shown in Figure 96 and described in Table 92. For additional programming see Section 2.3.3.

| Table 91. LSUn_REG2 Registers and the Associated LSUs |
|-------------------------------------------------------|
|-------------------------------------------------------|

| Register  | Address Offset | Associated LSU |
|-----------|----------------|----------------|
| LSU1_REG2 | 0408h          | LSU1           |
| LSU2_REG2 | 0428h          | LSU2           |
| LSU3_REG2 | 0448h          | LSU3           |
| LSU4_REG2 | 0468h          | LSU4           |

### Figure 96. LSUn Control Register 2 (LSUn\_REG2)

| 31 |              | 0 |
|----|--------------|---|
|    | DSP_ADDRESS  |   |
|    | R/W-0000000h |   |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 92. LSU*n* Control Register 2 (LSU*n*\_REG2) Field Descriptions

| Bit  | Field       | Value                        | Description                                                   |
|------|-------------|------------------------------|---------------------------------------------------------------|
| 31–0 | DSP_ADDRESS | 00000000h<br>to<br>FFFFFFFFh | 32-bit DSP byte address for the source of the LSU transaction |



## 5.36 LSUn Control Register 3 (LSUn\_REG3)

There are four of these registers, one for each LSU (see Table 93). LSU*n*\_REG3 is shown in Figure 97 and described in Table 94. For additional programming see Section 2.3.3.

#### Table 93. LSU*n*\_REG3 Registers and the Associated LSUs

| Register  | Address Offset | Associated LSU |  |
|-----------|----------------|----------------|--|
| LSU1_REG3 | 040Ch          | LSU1           |  |
| LSU2_REG3 | 042Ch          | LSU2           |  |
| LSU3_REG3 | 044Ch          | LSU3           |  |
| LSU4_REG3 | 046Ch          | LSU4           |  |

#### Figure 97. LSUn Control Register 3 (LSUn\_REG3)

| 31 |          |            | 16 |
|----|----------|------------|----|
|    |          | Reserved   |    |
|    |          | R-0000h    |    |
| 15 | 12 11    |            | 0  |
| R  | Reserved | BYTE_COUNT |    |
|    | R-0h     | R/W-000h   |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 94. LSUn Control Register 3 (LSUn\_REG3) Field Descriptions

| Bit   | Field      | Value     | Description                                                                                                                                                                                               |
|-------|------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–12 | Reserved   | 00000h    | These read-only bits return 0s when read.                                                                                                                                                                 |
| 11–0  | BYTE_COUNT | 000h-FFFh | Number of data bytes to read or write, up to 4K bytes. This value is used in conjunction with the specified RapidIO address to create the data size and word pointer fields in the RapidIO packet header. |

## 5.37 LSUn Control Register 4 (LSUn\_REG4)

There are four of these registers, one for each LSU (see Table 95). LSU*n*\_REG4 is shown in Figure 98 and described in Table 96. For additional programming see Section 2.3.3.

| Table 95. LSUn_REG4 Registers and the Associated LS | SUs |
|-----------------------------------------------------|-----|
|-----------------------------------------------------|-----|

| Register  | Address Offset | Associated LSU |
|-----------|----------------|----------------|
| LSU1_REG4 | 0410h          | LSU1           |
| LSU2_REG4 | 0430h          | LSU2           |
| LSU3_REG4 | 0450h          | LSU3           |
| LSU4_REG4 | 0470h          | LSU4           |

#### Figure 98. LSUn Control Register 4 (LSUn\_REG4)

| 31        | 30   | 29 |         | 28 | 27 |        | 26 | 25 | i       | 24 | 23       |           |   |                   |
|-----------|------|----|---------|----|----|--------|----|----|---------|----|----------|-----------|---|-------------------|
| OUTPO     | RTID | Р  | RIORITY | ,  |    | XAMSB  |    |    | ID_SIZE |    |          | DESTID    |   |                   |
| R/W-      | 00   | l  | R/W-00  |    |    | R/W-00 |    |    | R/W-00  |    |          | R/W-0000h |   |                   |
|           |      |    |         |    |    |        |    |    | 8       | 7  |          |           | 1 | 0                 |
|           |      |    | DE      | ST | D  |        |    |    |         |    | Reserved | d         |   | INTERRUPT_<br>REQ |
| R/W-0000h |      |    |         |    |    | R-00h  |    |    | R/W-0   |    |          |           |   |                   |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 96. LSUn Control Register 4 (LSUn\_REG4) Field Descriptions

| Bit   | Field         | Value   | Description                                                                                                                                                                                                                                                                 |
|-------|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30 | OUTPORTID     | 00b–11b | Indicates the number of the output port (0, 1, 2, or 3) from which the packet is to be transmitted. Specified by the CPU along with the node ID. The output port value is not included in the RapidIO header.                                                               |
| 29–28 | PRIORITY      | 00b–11b | Supplies the prio field of the RapidIO packet header to indicate packet priority. To avoid system deadlock, it is recommended that request packets not be sent with priority level 3. It is the responsibility of the software to assign the appropriate outgoing priority. |
| 27–26 | XAMSB         | 00b–11b | Supplies the xamsb field of the RapidIO packet header to specify the 2 MSBs of the extended RapidIO address.                                                                                                                                                                |
| 25–24 | ID_SIZE       |         | Supplies the tt field of the RapidIO packet header to specify whether 8-bit or 16-bit DeviceIDs are used.                                                                                                                                                                   |
|       |               | 00b     | 8 bit device IDs                                                                                                                                                                                                                                                            |
|       |               | 01b     | 16 bit device IDs                                                                                                                                                                                                                                                           |
|       |               | 1xb     | Reserved                                                                                                                                                                                                                                                                    |
| 23–8  | DESTID        | 0000h   | Supplies the destination ID field of the RapidIO packet header to specifying target device.                                                                                                                                                                                 |
| 7–1   | Reserved      | 00h     | These read-only bits return 0s when read.                                                                                                                                                                                                                                   |
| 0     | INTERRUPT_REQ |         | Indicates whether the CPU requests an interrupt upon completion of the LSU command. This is a CPU-controlled request bit and is typically used in conjunction with non-posted commands to alert the CPU when the requested data/status is present.                          |
|       |               | 0       | Interrupt not requested upon completion of command                                                                                                                                                                                                                          |
|       |               | 1       | Interrupt requested upon completion of command                                                                                                                                                                                                                              |



## 5.38 LSUn Control Register 5 (LSUn\_REG5)

There are four of these registers, one for each LSU (see Table 97). LSU*n*\_REG5 is shown in Figure 99 and described in Table 98. For additional programming see Section 2.3.3.

#### Table 97. LSUn\_REG5 Registers and the Associated LSUs

| Register  | Address Offset | Associated LSU |
|-----------|----------------|----------------|
| LSU1_REG5 | 0414h          | LSU1           |
| LSU2_REG5 | 0434h          | LSU2           |
| LSU3_REG5 | 0454h          | LSU3           |
| LSU4_REG5 | 0474h          | LSU4           |

#### Figure 99. LSUn Control Register 5 (LSUn\_REG5)

| 31 |           |            | 16       |
|----|-----------|------------|----------|
|    |           | DRBLL_INFO |          |
|    |           | R/W-0000h  |          |
| 15 |           | 8 7        | 0        |
|    | HOP_COUNT | PACł       | (ET_TYPE |
|    | R/W-00h   | R          | /W-00h   |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 98. LSUn Control Register 5 (LSUn\_REG5) Field Descriptions

| Bit   | Field       | Value       | Description                                                                                                                                       |
|-------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16 | DRBLL_INFO  | 0000h-FFFFh | RapidIO doorbell info field for type 10 packets. (see Table 23)                                                                                   |
| 15–8  | HOP_COUNT   | 00h–FFh     | RapidIO hop count field specified for type 8 (maintenance) packets                                                                                |
| 7–0   | PACKET_TYPE | 00h–FFh     | The 4 MSBs specify the ftype field for all packet types, and the 4 LSBs specify the trans field for packet types 2, 5, and 8. See Section 2.1.2.4 |

## 5.39 LSUn Control Register 6 (LSUn\_REG6)

There are four of these registers, one for each LSU (see Table 99). LSU*n*\_REG6 is shown in Figure 100 and described in Table 100. For additional programming see Section 2.3.3.

| Table 99. LSU <i>n_</i> REG6 Registers and the Associated LSUs |
|----------------------------------------------------------------|
|----------------------------------------------------------------|

| Register  | Address Offset | Associated LSU |
|-----------|----------------|----------------|
| LSU1_REG6 | 0418h          | LSU1           |
| LSU2_REG6 | 0438h          | LSU2           |
| LSU3_REG6 | 0458h          | LSU3           |
| LSU4_REG6 | 0478h          | LSU4           |

### Figure 100. LSUn Control Register 6 (LSUn\_REG6)

| 31 |          |          |    |                 |   | 16  |
|----|----------|----------|----|-----------------|---|-----|
|    |          | Reserved |    |                 |   |     |
|    |          | R-0000h  |    |                 |   |     |
| 15 |          |          | 54 |                 | 1 | 0   |
|    | Reserved |          |    | COMPLETION_CODE |   | BSY |
|    | R-000h   |          |    | R-0000          |   | R-0 |

LEGEND: R = Read only; -n = Value after reset

#### Table 100. LSUn Control Register 6 (LSUn\_REG6) Field Descriptions

| Bit  | Field           | Value  | Description                                                                                                                                   |
|------|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31–5 | Reserved        | 0000h  | These read-only bits return 0s when read.                                                                                                     |
| 4–1  | COMPLETION_CODE |        | Indicates the status of the pending command.                                                                                                  |
|      |                 | 0000b  | Transaction complete, no errors (posted/non-posted)                                                                                           |
|      |                 | 0001b  | Transaction timeout occurred on non-posted transaction                                                                                        |
|      |                 | 0010 b | Transaction complete, packet not sent due to flow control blockade (Xoff)                                                                     |
|      |                 | 0011b  | Transaction complete, non-posted response packet (type 8 and 13) contained ERROR status, or response payload length was in error              |
|      |                 | 0100b  | Transaction complete, packet not sent due to unsupported transaction type or invalid programming encoding for one or more LSU register fields |
|      |                 | 0101b  | DMA data transfer error                                                                                                                       |
|      |                 | 0110b  | "Retry" DOORBELL response received, or Atomic test-and-swap was not allowed (semaphore in use)                                                |
|      |                 | 0111b  | Transaction complete, packet not sent due to unavailable outbound credit at given priority                                                    |
|      |                 | 1xxxb  | Reserved                                                                                                                                      |
| 0    | BSY             |        | Indicates status of the writeable LSU registers                                                                                               |
|      |                 | 0      | LSU registers available (writable) for next set of transfer descriptors                                                                       |
|      |                 | 1      | LSU registers busy with current transfer                                                                                                      |



#### SRIO Registers

#### 5.40 LSUn Congestion Control Flow Mask Register (LSUn\_FLOW\_MASKS)

There are four of these registers, one for each LSU (see Table 101). The fields of an LSU*n*\_FLOW\_MASKS register are summarized by Figure 101 and described in Table 102. The 16 bits within each FLOW\_MASK field are summarized by Figure 102 and Table 103. For additional programming see Section 2.3.8.

| Register        | Address Offset | LSU  |
|-----------------|----------------|------|
| LSU1_FLOW_MASKS | 041Ch          | LSU1 |
| LSU2_FLOW_MASKS | 043Ch          | LSU2 |
| LSU3_FLOW_MASKS | 045Ch          | LSU3 |
| LSU4_FLOW_MASKS | 047Ch          | LSU4 |

#### Table 101. LSU*n*\_FLOW\_MASKS Registers and the Associated LSUs

#### Figure 101. LSU*n* Congestion Control Flow Mask Register (LSU*n*\_FLOW\_MASKS)

| 31 16    | 15 0      |
|----------|-----------|
| Reserved | FLOW_MASK |
| R-00h    | R/W-FFh   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

#### Table 102. LSUn Congestion Control Flow Mask Register (LSUn\_FLOW\_MASKS) Field Descriptions

| Bit                | Field     | Value   | Description                               |
|--------------------|-----------|---------|-------------------------------------------|
| 31–16 Reserved 00h |           |         | These read-only bits return 0s when read. |
| 15–0               | FLOW_MASK | 00h-FFh | Flow mask for LSUn                        |

#### Figure 102. LSUn FLOW\_MASK Fields

| 15    | 14                                                    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| FL15  | FL14                                                  | FL13  | FL12  | FL11  | FL10  | FL9   | FL8   | FL7   | FL6   | FL5   | FL4   | FL3   | FL2   | FL1   | FL0   |
| R/W-1 | R/W-1                                                 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
| LEGEN | LEGEND: R = Read: W = Write: $-n$ = Value after reset |       |       |       |       |       |       |       |       |       |       |       |       |       |       |

#### Table 103. LSUn FLOW\_MASK Fields

| Bit | Field | Value | Description                                    |  |
|-----|-------|-------|------------------------------------------------|--|
| 15  | FL15  | 0     | LSUn does not support Flow 15 from table entry |  |
|     |       | 1     | LSU <i>n</i> supports Flow 15 from table entry |  |
| 14  | FL14  | 0     | LSUn does not support Flow 14 from table entry |  |
|     |       | 1     | LSUn supports Flow 14 from table entry         |  |
| 13  | FL13  | 0     | LSUn does not support Flow 13 from table entry |  |
|     |       | 1     | LSUn supports Flow 13 from table entry         |  |
| 12  | FL12  | 0     | LSUn does not support Flow 12 from table entry |  |
|     |       | 1     | LSU <i>n</i> supports Flow 12 from table entry |  |
| 11  | FL11  | 0     | LSUn does not support Flow 11 from table entry |  |
|     |       | 1     | LSU <i>n</i> supports Flow 11 from table entry |  |
| 10  | FL10  | 0     | LSUn does not support Flow 10 from table entry |  |
|     |       | 1     | LSUn supports Flow 10 from table entry         |  |
| 9   | FL9   | 0     | LSUn does not support Flow 9 from table entry  |  |
|     |       | 1     | LSUn supports Flow 9 from table entry          |  |

| Bit | Field                                                         | Value                                                   | Description                                   |  |
|-----|---------------------------------------------------------------|---------------------------------------------------------|-----------------------------------------------|--|
| 8   | FL8                                                           | 0                                                       | LSUn does not support Flow 8 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 8 from table entry         |  |
| 7   | FL7                                                           | 0                                                       | LSUn does not support Flow 7 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 7 from table entry         |  |
| 6   | FL6                                                           | 0                                                       | LSUn does not support Flow 6 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 6 from table entry         |  |
| 5   | FL5                                                           | 0                                                       | LSUn does not support Flow 5 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 5 from table entry         |  |
| 4   | FL4                                                           | 0                                                       | LSUn does not support Flow 4 from table entry |  |
|     |                                                               | 1                                                       | LSU <i>n</i> supports Flow 4 from table entry |  |
| 3   | FL3                                                           | 0 LSU <i>n</i> does not support Flow 3 from table entry |                                               |  |
|     |                                                               | 1                                                       | LSUn supports Flow 3 from table entry         |  |
| 2   | 2 FL2 0 LSU <i>n</i> does not support Flow 2 from table entry |                                                         | LSUn does not support Flow 2 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 2 from table entry         |  |
| 1   | FL1                                                           | 0                                                       | LSUn does not support Flow 1 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 1 from table entry         |  |
| 0   | FL0                                                           | 0                                                       | LSUn does not support Flow 0 from table entry |  |
|     |                                                               | 1                                                       | LSUn supports Flow 0 from table entry         |  |

### Table 103. LSUn FLOW\_MASK Fields (continued)



#### 5.41 Queue n Transmit DMA Head Descriptor Pointer Register (QUEUEn\_TXDMA\_HDP)

There are sixteen of these registers (see Table 104). QUEUE*n*\_TXDMA\_HDP is shown in Figure 103 and described in Table 105. For additional programming information, see Section 2.3.4.2.

| Register          | Address Offset |  |  |  |
|-------------------|----------------|--|--|--|
| QUEUE0_TXDMA_HDP  | 0500h          |  |  |  |
| QUEUE1_TXDMA_HDP  | 0504h          |  |  |  |
| QUEUE2_TXDMA_HDP  | 0508h          |  |  |  |
| QUEUE3_TXDMA_HDP  | 050Ch          |  |  |  |
| QUEUE4_TXDMA_HDP  | 0510h          |  |  |  |
| QUEUE5_TXDMA_HDP  | 0514h          |  |  |  |
| QUEUE6_TXDMA_HDP  | 0518h          |  |  |  |
| QUEUE7_TXDMA_HDP  | 051Ch          |  |  |  |
| QUEUE8_TXDMA_HDP  | 0520h          |  |  |  |
| QUEUE9_TXDMA_HDP  | 0524h          |  |  |  |
| QUEUE10_TXDMA_HDP | 0528h          |  |  |  |
| QUEUE11_TXDMA_HDP | 052Ch          |  |  |  |
| QUEUE12_TXDMA_HDP | 0530h          |  |  |  |
| QUEUE13_TXDMA_HDP | 0534h          |  |  |  |
| QUEUE14_TXDMA_HDP | 0538h          |  |  |  |
| QUEUE15_TXDMA_HDP | 053Ch          |  |  |  |

#### Table 104. QUEUEn\_TXDMA\_HDP Registers

#### Figure 103. Queue *n* Transmit DMA Head Descriptor Pointer Register (QUEUE*n*\_TXDMA\_HDP)

| 31 |              | 0 |
|----|--------------|---|
|    | TX_HDP       |   |
|    | R/W-0000000h |   |

LEGEND: R/W = Read/Write; -n = Value after reset

## Table 105. Queue n Transmit DMA Head Descriptor Pointer Register (QUEUEn\_TXDMA\_HDP) Field Descriptions

| Bit  | Field  | Value                        | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|--------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | TX_HDP | 00000000h<br>to<br>FFFFFFFCh | This field is the memory address for the first buffer descriptor in the transmit queue. This field is written by the DSP core to initiate queue transmit operations and is zeroed by the port when all packets in the queue have been transmitted. An error condition results if the DSP core writes this field when the current field value is nonzero. The address must be 32-bit word aligned (the 2 LSBs must be 0s). |

### 5.42 Queue n Transmit DMA Completion Pointer Register (QUEUEn\_TXDMA\_CP)

There are sixteen of these registers (see Table 106). QUEUE*n*\_TXDMA\_CP is shown in Figure 104 and described in Table 107. For additional programming information, see Section 2.3.4.2.

| Register         | Address Offset |  |  |  |
|------------------|----------------|--|--|--|
| QUEUE0_TXDMA_CP  | 0580h          |  |  |  |
| QUEUE1_TXDMA_CP  | 0584h          |  |  |  |
| QUEUE2_TXDMA_CP  | 0588h          |  |  |  |
| QUEUE3_TXDMA_CP  | 058Ch          |  |  |  |
| QUEUE4_TXDMA_CP  | 0590h          |  |  |  |
| QUEUE5_TXDMA_CP  | 0594h          |  |  |  |
| QUEUE6_TXDMA_CP  | 0598h          |  |  |  |
| QUEUE7_TXDMA_CP  | 059Ch          |  |  |  |
| QUEUE8_TXDMA_CP  | 05A0h          |  |  |  |
| QUEUE9_TXDMA_CP  | 05A4h          |  |  |  |
| QUEUE10_TXDMA_CP | 05A8h          |  |  |  |
| QUEUE11_TXDMA_CP | 05ACh          |  |  |  |
| QUEUE12_TXDMA_CP | 05B0h          |  |  |  |
| QUEUE13_TXDMA_CP | 05B4h          |  |  |  |
| QUEUE14_TXDMA_CP | 05B8h          |  |  |  |
| QUEUE15_TXDMA_CP | 05BCh          |  |  |  |

#### Table 106. QUEUE*n*\_TXDMA\_CP Registers

#### Figure 104. Queue *n* Transmit DMA Completion Pointer Register (QUEUE*n*\_TXDMA\_CP)

| 31           | 0 |
|--------------|---|
| TX_CP        |   |
| R/W-0000000h |   |

LEGEND: R/W = Read/Write; -n = Value after reset

## Table 107. Queue Transmit DMA Completion Pointer Registers (QUEUEn\_TXDMA\_CP) Field Descriptions

| Bit  | Field | Value                       | Description                                                                                                                                                                                                                                                                                                        |
|------|-------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | TX_CP | 00000000h<br>to<br>FFFFFFFh | This field is the memory address for the transmit queue completion pointer. This register is written by the DSP core with the buffer descriptor address for the last buffer processed by the host during interrupt processing. The port uses the value written to determine if the interrupt should be deasserted. |



#### 5.43 Queue n Receive DMA Head Descriptor Pointer Register (QUEUEn\_RXDMA\_HDP)

There are sixteen of these registers (see Table 108). QUEUE*n*\_RXDMA\_HDP is shown in Figure 105 and described in Table 109. For additional programming information, see Section 2.3.4.1.

| Register          | Address Offset |  |
|-------------------|----------------|--|
| QUEUE0_RXDMA_HDP  | 0600h          |  |
| QUEUE1_RXDMA_HDP  | 0604h          |  |
| QUEUE2_RXDMA_HDP  | 0608h          |  |
| QUEUE3_RXDMA_HDP  | 060Ch          |  |
| QUEUE4_RXDMA_HDP  | 0610h          |  |
| QUEUE5_RXDMA_HDP  | 0614h          |  |
| QUEUE6_RXDMA_HDP  | 0618h          |  |
| QUEUE7_RXDMA_HDP  | 061Ch          |  |
| QUEUE8_RXDMA_HDP  | 0620h          |  |
| QUEUE9_RXDMA_HDP  | 0624h          |  |
| QUEUE10_RXDMA_HDP | 0628h          |  |
| QUEUE11_RXDMA_HDP | 062Ch          |  |
| QUEUE12_RXDMA_HDP | 0630h          |  |
| QUEUE13_RXDMA_HDP | 0634h          |  |
| QUEUE14_RXDMA_HDP | 0638h          |  |
| QUEUE15_RXDMA_HDP | 063Ch          |  |

#### Table 108. QUEUE*n*\_RXDMA\_HDP Registers

#### Figure 105. Queue *n* Receive DMA Head Descriptor Pointer Register (QUEUE*n*\_RXDMA\_HDP)

| 31 | 0            |
|----|--------------|
|    | RX_HDP       |
|    | R/W-0000000h |

LEGEND: R/W = Read/Write; -n = Value after reset

## Table 109. Queue n Receive DMA Head Descriptor Pointer Register (QUEUEn\_RXDMA\_HDP) Field Descriptions

| Bit  | Field  | Value                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|--------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | RX_HDP | 00000000h<br>to<br>FFFFFFFCh | RX Queue Head Descriptor Pointer: This field is the memory address for the first buffer descriptor in the channel receive queue. This field is written by the DSP core to initiate queue receive operations and is zeroed by the port when all free buffers have been used. An error condition results if the DSP core writes this field when the current field value is nonzero. The address must be 32-bit word aligned (the 2 LSBs must be 0s). |

#### 5.44 Queue n Receive DMA Completion Pointer Register (QUEUEn\_RXDMA\_CP)

There are sixteen of these registers (see Table 110). QUEUE*n*\_RXDMA\_CP is shown in Figure 106 and described in Table 111. For additional programming information, see Section 2.3.4.1.

| Register         | Address Offset |  |  |  |
|------------------|----------------|--|--|--|
| QUEUE0_RXDMA_CP  | 0680h          |  |  |  |
| QUEUE1_RXDMA_CP  | 0684h          |  |  |  |
| QUEUE2_RXDMA_CP  | 0688h          |  |  |  |
| QUEUE3_RXDMA_CP  | 068Ch          |  |  |  |
| QUEUE4_RXDMA_CP  | 0690h          |  |  |  |
| QUEUE5_RXDMA_CP  | 0694h          |  |  |  |
| QUEUE6_RXDMA_CP  | 0698h          |  |  |  |
| QUEUE7_RXDMA_CP  | 069Ch          |  |  |  |
| QUEUE8_RXDMA_CP  | 06A0h          |  |  |  |
| QUEUE9_RXDMA_CP  | 06A4h          |  |  |  |
| QUEUE10_RXDMA_CP | 06A8h          |  |  |  |
| QUEUE11_RXDMA_CP | 06ACh          |  |  |  |
| QUEUE12_RXDMA_CP | 06B0h          |  |  |  |
| QUEUE13_RXDMA_CP | 06B4h          |  |  |  |
| QUEUE14_RXDMA_CP | 06B8h          |  |  |  |
| QUEUE15_RXDMA_CP | 06BCh          |  |  |  |

#### Table 110. QUEUE*n*\_RXDMA\_CP Registers

#### Figure 106. Queue *n* Receive DMA Completion Pointer Register (QUEUE*n*\_RXDMA\_CP)

| 31 |              | 0 |
|----|--------------|---|
|    | RX_CP        |   |
|    | R/W-0000000h |   |

LEGEND: R/W = Read/Write; -*n* = Value after reset

## Table 111. Queue n Receive DMA Completion Pointer Register (QUEUEn\_RXDMA\_CP) Field Descriptions

| Bit  | Field | Value                        | Description                                                                                                                                                                                                                                                                                                           |
|------|-------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | RX_CP | 00000000h<br>to<br>FFFFFFFFh | This field is the memory address for the receive queue completion pointer. This register is written by the DSP core with the buffer descriptor address for the last buffer processed by the DSP core during interrupt processing. The port uses the value written to determine if the interrupt should be deasserted. |



### 5.45 Transmit Queue Teardown Register (TX\_QUEUE\_TEAR\_DOWN)

Each bit in this register corresponds to one of the 16 TX buffer descriptor queues. If a 1 is written to a bit, the teardown process is initiated for the associated queue. TX\_QUEUE\_TEAR\_DOWN is shown in Figure 107 and described in Table 112.

#### Figure 107. Transmit Queue Teardown Register (TX\_QUEUE\_TEAR\_DOWN) - Address Offset 0700h

| 31                   |                      |                      |                      |                      |                      |                     | 16                  |
|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|
|                      |                      |                      | Rese                 | erved                |                      |                     |                     |
|                      |                      |                      | R-00                 | 000h                 |                      |                     |                     |
| 15                   | 14                   | 13                   | 12                   | 11                   | 10                   | 9                   | 8                   |
| QUEUE15_<br>TEAR_DWN | QUEUE14_<br>TEAR_DWN | QUEUE13_<br>TEAR_DWN | QUEUE12_<br>TEAR_DWN | QUEUE11_<br>TEAR_DWN | QUEUE10_<br>TEAR_DWN | QUEUE9_<br>TEAR_DWN | QUEUE8_<br>TEAR_DWN |
| W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                 | W-0                 |
| 7                    | 6                    | 5                    | 4                    | 3                    | 2                    | 1                   | 0                   |
| QUEUE7_<br>TEAR_DWN  | QUEUE6_<br>TEAR_DWN  | QUEUE5_<br>TEAR_DWN  | QUEUE4_<br>TEAR_DWN  | QUEUE3_<br>TEAR_DWN  | QUEUE2_<br>TEAR_DWN  | QUEUE1_<br>TEAR_DWN | QUEUE0_<br>TEAR_DWN |
| W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                 | W-0                 |

LEGEND: R = Read only; W = Write only; -n = Value after reset

#### Table 112. Transmit Queue Teardown Register (TX\_QUEUE\_TEAR\_DOWN) Field Descriptions

| Bit   | Field           | Value | Description                                |
|-------|-----------------|-------|--------------------------------------------|
| 31–16 | Reserved        | 0     | These read-oinly bits return 0s when read. |
| 15–0  | QUEUEn_TEAR_DWN |       | Queue <i>n</i> tear down                   |
|       | (n = 15 to 0)   | 0     | No effect                                  |
|       |                 | 1     | Tear down Queue <i>n</i> .                 |

## 5.46 Transmit CPPI Supported Flow Mask Registers (TX\_CPPI\_FLOW\_MASKS[0-7])

Each of the eight TX CPPI flow mask registers holds the flow masks for two TX descriptor buffer queues (see Table 113). Figure 108 shows the registers, and Figure 109 shows the general form of a flow mask. Each bit of a flow mask selects or deselects a flow for the associated TX queue (see Table 114). For additional programming information, see Section 2.3.8.

Table 113. TX\_CPPI\_FLOW\_MASKS Registers and the Associated TX Queues

| Register            | Address Offset | Associated TX Queues |
|---------------------|----------------|----------------------|
| TX_CPPI_FLOW_MASKS0 | 0704h          | Queues 0 and 1       |
| TX_CPPI_FLOW_MASKS1 | 0708h          | Queues 2 and 3       |
| TX_CPPI_FLOW_MASKS2 | 070Ch          | Queues 4 and 5       |
| TX_CPPI_FLOW_MASKS3 | 0710h          | Queues 6 and 7       |
| TX_CPPI_FLOW_MASKS4 | 0714h          | Queues 8 and 9       |
| TX_CPPI_FLOW_MASKS5 | 0718h          | Queues 10 and 11     |
| TX_CPPI_FLOW_MASKS6 | 071Ch          | Queues 12 and 13     |
| TX_CPPI_FLOW_MASKS7 | 0720h          | Queues 14 and 15     |



SRIO Registers

| Figure 108. Transmit CF                                   | PPI Supported Flow Mask Registers |
|-----------------------------------------------------------|-----------------------------------|
| Transmit CPPI Supported Flow Mask Register 0 (TX_CPPI_FLO | DW_MASKS0)                        |
| 31 16                                                     | 6 15 0                            |
| QUEUE1_FLOW_MASK                                          | QUEUE0_FLOW_MASK                  |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 1 (TX_CPPI_FL  | DW_MASKS1)                        |
| 31 16                                                     | S 15 0                            |
| QUEUE3_FLOW_MASK                                          | QUEUE2_FLOW_MASK                  |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 2 (TX_CPPI_FL  | DW_MASKS2)                        |
| 31 16                                                     | S 15 0                            |
| QUEUE5_FLOW_MASK                                          | QUEUE4_FLOW_MASK                  |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 3 (TX_CPPI_FL  | DW_MASKS3)                        |
| 31 16                                                     | 6 15 O                            |
| QUEUE7_FLOW_MASK                                          | QUEUE6_FLOW_MASK                  |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 4 (TX_CPPI_FL  | DW_MASKS4)                        |
| 31 16                                                     | 5 15 O                            |
| QUEUE9_FLOW_MASK                                          | QUEUE8_FLOW_MASK                  |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 5 (TX_CPPI_FL  | DW_MASKS5)                        |
| 31 16                                                     | 6 15 0                            |
| QUEUE11_FLOW_MASK                                         | QUEUE10_FLOW_MASK                 |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 6 (TX_CPPI_FL  | DW_MASKS6)                        |
| 31 16                                                     | 6 15 0                            |
| QUEUE13_FLOW_MASK                                         | QUEUE12_FLOW_MASK                 |
| R/W-FFh                                                   | R/W-FFh                           |
| Transmit CPPI Supported Flow Mask Register 7 (TX_CPPI_FL  | DW_MASKS7)                        |
| 31 16                                                     | -                                 |
| QUEUE15_FLOW_MASK                                         | QUEUE14_FLOW_MASK                 |
| R/W-FFh                                                   | R/W-FFh                           |
| LEGEND: R/W = Read/Write; - <i>n</i> = Value after reset  |                                   |

## Figure 109. TX Queue *n* FLOW\_MASK Fields

| 15                                               | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| FL15                                             | FL14  | FL13  | FL12  | FL11  | FL10  | FL9   | FL8   | FL7   | FL6   | FL5   | FL4   | FL3   | FL2   | FL1   | FL0   |
| R/W-1                                            | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
| LEGEND: R/W = Read/Write; -n = Value after reset |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |

| Bit | Field | Value | Description                                              |
|-----|-------|-------|----------------------------------------------------------|
| 15  | FL15  | 0     | Queue <i>n</i> does not support Flow 15 from table entry |
|     |       | 1     | Queue <i>n</i> supports Flow 15 from table entry         |
| 14  | FL14  | 0     | Queue <i>n</i> does not support Flow 14 from table entry |
|     |       | 1     | Queue <i>n</i> supports Flow 14 from table entry         |
| 13  | FL13  | 0     | Queue <i>n</i> does not support Flow 13 from table entry |
|     |       | 1     | Queue <i>n</i> supports Flow 13 from table entry         |

|     |       |       | TX Queue h FLOW_MASK Field Descriptions (continued)      |
|-----|-------|-------|----------------------------------------------------------|
| Bit | Field | Value | Description                                              |
| 12  | FL12  | 0     | Queue <i>n</i> does not support Flow 12 from table entry |
|     |       | 1     | Queue <i>n</i> supports Flow 12 from table entry         |
| 11  | FL11  | 0     | Queue n does not support Flow 11 from table entry        |
|     |       | 1     | Queue <i>n</i> supports Flow 11 from table entry         |
| 10  | FL10  | 0     | Queue n does not support Flow 10 from table entry        |
|     |       | 1     | Queue <i>n</i> supports Flow 10 from table entry         |
| 9   | FL9   | 0     | Queue n does not support Flow 9 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 9 from table entry          |
| 8   | FL8   | 0     | Queue n does not support Flow 8 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 8 from table entry          |
| 7   | FL7   | 0     | Queue n does not support Flow 7 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 7 from table entry          |
| 6   | FL6   | 0     | Queue n does not support Flow 6 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 6 from table entry          |
| 5   | FL5   | 0     | Queue n does not support Flow 5 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 5 from table entry          |
| 4   | FL4   | 0     | Queue n does not support Flow 4 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 4 from table entry          |
| 3   | FL3   | 0     | Queue n does not support Flow 3 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 3 from table entry          |
| 2   | FL2   | 0     | Queue n does not support Flow 2 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 2 from table entry          |
| 1   | FL1   | 0     | Queue n does not support Flow 1 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 1 from table entry          |
| 0   | FL0   | 0     | Queue n does not support Flow 0 from table entry         |
|     |       | 1     | Queue <i>n</i> supports Flow 0 from table entry          |

### Table 114. TX Queue n FLOW\_MASK Field Descriptions (continued)



#### SRIO Registers

#### 5.47 Receive Queue Teardown Register (RX\_QUEUE\_TEAR\_DOWN)

Each of this register's bits corresponds to one of the 16 RX buffer descriptor queues. If a 1 is written to a bit, the teardown process is started for the associated queue. RX\_QUEUE\_TEAR\_DOWN is shown in Figure 110 and described in Table 115. For additional programming information, see Section 2.3.4.1.

#### Figure 110. Receive Queue Teardown Register (RX\_QUEUE\_TEAR\_DOWN) (Address Offset 0740h)

| 31                   |                      |                      |                      |                      |                      |                     | 16                  |
|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|
|                      |                      |                      | Rese                 | erved                |                      |                     |                     |
|                      |                      |                      | R-00                 | 000h                 |                      |                     |                     |
| 15                   | 14                   | 13                   | 12                   | 11                   | 10                   | 9                   | 8                   |
| QUEUE15_<br>TEAR_DWN | QUEUE14_<br>TEAR_DWN | QUEUE13_<br>TEAR_DWN | QUEUE12_<br>TEAR_DWN | QUEUE11_<br>TEAR_DWN | QUEUE10_<br>TEAR_DWN | QUEUE9_<br>TEAR_DWN | QUEUE8_<br>TEAR_DWN |
| W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                 | W-0                 |
| 7                    | 6                    | 5                    | 4                    | 3                    | 2                    | 1                   | 0                   |
| QUEUE7_<br>TEAR_DWN  | QUEUE6_<br>TEAR_DWN  | QUEUE5_<br>TEAR_DWN  | QUEUE4_<br>TEAR_DWN  | QUEUE3_<br>TEAR_DWN  | QUEUE2_<br>TEAR_DWN  | QUEUE1_<br>TEAR_DWN | QUEUE0_<br>TEAR_DWN |
| W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                  | W-0                 | W-0                 |

LEGEND: R = Read only; W = Write; -n = Value after reset

#### Table 115. Receive Queue Teardown Register (RX\_QUEUE\_TEAR\_DOWN) Field Descriptions

| Bit   | Field           | Value | Description                               |
|-------|-----------------|-------|-------------------------------------------|
| 31–16 | Reserved        | 0000h | These read-only bits return 0s when read. |
| 15–0  | QUEUEn_TEAR_DWN |       | Queue <i>n</i> tear down                  |
|       | (n = 15 to 0)   | 0     | No effect                                 |
|       |                 | 1     | Tear down Queue <i>n</i> .                |

## 5.48 Receive CPPI Control Register (RX\_CPPI\_CNTL)

Each bit in this register indicates whether the associated RX buffer descriptor queue must receive messages in the order the source device attempts to transmit them. RX\_CPPI\_CNTL is shown in and described in Table 116. For additional programming information, see Section 2.3.4.1.

### Figure 111. Receive CPPI Control Register (RX\_CPPI\_CNTL) (Address Offset 0744h)

| 31                   |                      |                      |                      |                      |                      |                     | 24                  |
|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|---------------------|
|                      | Reserved             |                      |                      |                      |                      |                     |                     |
|                      |                      |                      | R-(                  | 00h                  |                      |                     |                     |
| 23                   |                      |                      |                      |                      |                      |                     | 16                  |
|                      |                      |                      | Rese                 | erved                |                      |                     |                     |
|                      | R-00h                |                      |                      |                      |                      |                     |                     |
| 15                   | 14                   | 13                   | 12                   | 11                   | 10                   | 9                   | 8                   |
| QUEUE15_<br>IN_ORDER | QUEUE14_<br>IN_ORDER | QUEUE13_<br>IN_ORDER | QUEUE12_<br>IN_ORDER | QUEUE11_<br>IN_ORDER | QUEUE10_<br>IN_ORDER | QUEUE9_<br>IN_ORDER | QUEUE8_<br>IN_ORDER |
| R/W-0                | R/W-0                | R/W-0                | R/W-0                | R/W-0                | R/W-0                | R/W-0               | R/W-0               |
| 7                    | 6                    | 5                    | 4                    | 3                    | 2                    | 1                   | 0                   |
| QUEUE7_<br>IN_ORDER  | QUEUE6_<br>IN_ORDER  | QUEUE5_<br>IN_ORDER  | QUEUE4_<br>IN_ORDER  | QUEUE3_<br>IN_ORDER  | QUEUE2_<br>IN_ORDER  | QUEUE1_<br>IN_ORDER | QUEUE0_<br>IN_ORDER |
| R/W-0                | R/W-0                | R/W-0                | R/W-0                | R/W-0                | R/W-0                | R/W-0               | R/W-0               |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

#### Table 116. Receive CPPI Control Register (RX\_CPPI\_CNTL) Field Descriptions

| Bit   | Field           | Value | Description                                                                                         |
|-------|-----------------|-------|-----------------------------------------------------------------------------------------------------|
| 31–16 | Reserved        | 0000h | Reserved                                                                                            |
| 15–0  | QUEUEn_IN_ORDER |       | Queuen in order                                                                                     |
|       | (n = 15 to 0)   | 0     | Allows out-of-order message reception                                                               |
|       |                 | 1     | Requires in-order message reception. Used for applications with dedicated source-destination flows. |



#### 5.49 Transmit CPPI Weighted Round Robin Control Registers (TX\_QUEUE\_CNTL[0-3])

The transmission order among TX buffer descriptor queues is based on the programmable weighted round-robin scheme explained in Section 2.3.4.2. As part of this scheme, software must program the 16 mappers to determine the order in which the queues are serviced and how many messages are handled in each queue during each time around the round-robin cycle. The mappers are programmed with the registers shown in Figure 112. The register fields are described in Table 117. For additional programming information, see Section 2.3.4.2.

#### Figure 112. Transmit CPPI Weighted Round Robin Control Registers

|      | QUEUE_CNTL0 - Address Of |               |    | 1                            |                |               |    |
|------|--------------------------|---------------|----|------------------------------|----------------|---------------|----|
| <    | > TX_Queue_Map3>         |               |    | <                            | TX_Qι          | Jeue_Map2     | >  |
| 31   | 28                       | 27            | 24 | 23                           | 20             | ) 19          | 16 |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0h                   | R/W-3h        |    |                              | R/W-0          | R/W-2h        |    |
| <    | TX_Que                   | eue_Map1      | <  | TX_Qu                        | Jeue_Map0      | >             |    |
| 15   | 12                       | 11            | 8  | 7                            | 4              | 4 3           | 0  |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0h                   | R/W-1h        |    |                              | R/W-0h         | R/W-0h        |    |
|      | QUEUE_CNTL1 - Address Of |               |    |                              |                |               |    |
| <    | TX_Que                   | eue_Map7      | >  | <                            | TX_Qu          | Jeue_Map6     | >  |
| 31   | 28                       | 27            | 24 | 23                           | 20             | ) 19          | 16 |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0                    | R/W-7h        |    |                              | R/W-0h         | R/W-6h        |    |
| <    | TX_Que                   | eue_Map5      | >  | <                            | TX_Qu          | Jeue_Map4     | >  |
| 15   | 12                       | 11            | 8  | 7                            | 4              | 4 3           | 0  |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0h                   | R/W-5h        |    |                              | R/W-0h         | R/W-4h        |    |
| тх_с | QUEUE_CNTL2 - Address Of | fset 07E8h    |    |                              |                |               |    |
| <    | TX_Que                   | ue_Map11      | >  | <                            | TX_Qu          | eue_Map10     | >  |
| 31   | 28                       | 27            | 24 | 23 20 19                     |                |               | 16 |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0h                   | R/W-Bh        |    |                              | R/W-0h         | R/W-Ah        |    |
| <    | TX_Que                   | eue_Map9      | >  | <                            | TX_Qu          | Jeue_Map8     | >  |
| 15   | 12                       | 11            | 8  | 7                            | 4              | 4 3           | 0  |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0h                   | R/W-9h        |    |                              | R/W-0h         | R/W-8h        |    |
| TX_C | QUEUE_CNTL3 - Address Of | fset 07ECh    |    |                              |                |               |    |
| <    | TX_Que                   | ue_Map15      | >  | < TX_Queue_Map14             |                |               | >  |
| 31   | 28                       | 27            | 24 | 23                           | 20             | ) 19          | 16 |
|      | Number of Msgs           | Queue Pointer |    | Number of Msgs Queue Pointer |                |               |    |
|      | R/W-0h                   | R/W-Fh        |    |                              | R/W-0h         | R/W-Eh        |    |
| <    | <> TX_Queue_Map13>       |               |    |                              | TX_Qu          | eue_Map12     | >  |
| 15   | 12                       | 11            | 8  | 7                            | 4              | 3             | 0  |
|      | Number of Msgs           | Queue Pointer |    |                              | Number of Msgs | Queue Pointer |    |
|      | R/W-0h                   | R/W-Dh        |    |                              | R/W-0h         | R/W-Ch        |    |

| Field Pair    | Register[Bits]        | Field          | Value    | Description                                                                                                         |
|---------------|-----------------------|----------------|----------|---------------------------------------------------------------------------------------------------------------------|
| TX_Queue_Map0 | TX_QUEUE_CNTL0[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|               | TX_QUEUE_CNTL0[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map1.                        |
| TX_Queue_Map1 | TX_QUEUE_CNTL0[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|               | TX_QUEUE_CNTL0[15-12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map2.                        |
| TX_Queue_Map2 | TX_QUEUE_CNTL0[19–16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL0[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map3.                        |
| TX_Queue_Map3 | TX_QUEUE_CNTL0[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL0[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map4.                        |
| TX_Queue_Map4 | TX_QUEUE_CNTL1[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|               | TX_QUEUE_CNTL1[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map5.                        |
| TX_Queue_Map5 | TX_QUEUE_CNTL1[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL1[15–12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map6.                        |
| TX_Queue_Map6 | TX_QUEUE_CNTL1[19–16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL1[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map7.                        |
| TX_Queue_Map7 | TX_QUEUE_CNTL1[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL1[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map8.                        |
| TX_Queue_Map8 | TX_QUEUE_CNTL2[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|               | TX_QUEUE_CNTL2[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map9.                        |

## Table 117. Transmit CPPI Weighted Round Robin Control Register Field Descriptions

|                |                       | 1              |          |                                                                                                                     |
|----------------|-----------------------|----------------|----------|---------------------------------------------------------------------------------------------------------------------|
| Field Pair     | Register[Bits]        | Field          | Value    | Description                                                                                                         |
| TX_Queue_Map9  | TX_QUEUE_CNTL2[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL2[15–12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map10.                       |
| TX_Queue_Map10 | TX_QUEUE_CNTL2[19–16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL2[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map11.                       |
| TX_Queue_Map11 | TX_QUEUE_CNTL2[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL2[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map12.                       |
| TX_Queue_Map12 | TX_QUEUE_CNTL3[3-0]   | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL3[7-4]   | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map13.                       |
| TX_Queue_Map13 | TX_QUEUE_CNTL3[11-8]  | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL3[15–12] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map14.                       |
| TX_Queue_Map14 | TX_QUEUE_CNTL3[19–16] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be programmed to point to any one of the 16 TX buffer descriptor queues.       |
|                | TX_QUEUE_CNTL3[23-20] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map15.                       |
| TX_Queue_Map15 | TX_QUEUE_CNTL3[27-24] | Queue Pointer  | 0h to Fh | Pointer to a queue. This pointer can be<br>programmed to point to any one of the 16<br>TX buffer descriptor queues. |
|                | TX_QUEUE_CNTL3[31-28] | Number of Msgs | 0h to Fh | Number of contiguous messages<br>(descriptors) to process before moving to<br>TX_Queue_Map0.                        |

## Table 117. Transmit CPPI Weighted Round Robin Control Register Field Descriptions (continued)

## 5.50 Mailbox to Queue Mapping Registers (RXU\_MAP\_Ln and RXU\_MAP\_Hn)

Messages addressed to any of the 64 mailbox locations can be received on any of the RapidIO ports simultaneously. Packets are handled sequentially in order of receipt. A block of 32 mappers directs the inbound messages to the appropriate RX queues. After a device reset, software must configure each of the mappers to map incoming messages with selected mailbox and letter numbers to the desired queue. For a given mapper n, a pair of mailbox to queue mapping registers fully define the configuration for that mapper: a low register (RXU\_MAP\_L*n*) and a high register (RXU\_MAP\_H*n*). Table 118 lists all of these register pairs and the associated RX mappers. The general form of an RXU\_MAP register pair is summarized by Figure 113, Table 119, and Table 120. For additional programming information, see Section 2.3.4.1.

| Register    | Address Offset | Associated RX Mapper |
|-------------|----------------|----------------------|
| RXU_MAP_L0  | 0800h          | Mapper 0             |
| RXU_MAP_H0  | 0804h          | Mapper 0             |
| RXU_MAP_L1  | 0808h          | Mapper 1             |
| RXU_MAP_H1  | 080Ch          | Mapper 1             |
| RXU_MAP_L2  | 0810h          | Mapper 2             |
| RXU_MAP_H2  | 0814h          | Mapper 2             |
| RXU_MAP_L3  | 0818h          | Mapper 3             |
| RXU_MAP_H3  | 081Ch          | Mapper 3             |
| RXU_MAP_L4  | 0820h          | Mapper 4             |
| RXU_MAP_H4  | 0824h          | Mapper 4             |
| RXU_MAP_L5  | 0828h          | Mapper 5             |
| RXU_MAP_H5  | 082Ch          | Mapper 5             |
| RXU_MAP_L6  | 0830h          | Mapper 6             |
| RXU_MAP_H6  | 0834h          | Mapper 6             |
| RXU_MAP_L7  | 0838h          | Mapper 7             |
| RXU_MAP_H7  | 083Ch          | Mapper 7             |
| RXU_MAP_L8  | 0840h          | Mapper 8             |
| RXU_MAP_H8  | 0844h          | Mapper 8             |
| RXU_MAP_L9  | 0848h          | Mapper 9             |
| RXU_MAP_H9  | 084Ch          | Mapper 9             |
| RXU_MAP_L10 | 0850h          | Mapper 10            |
| RXU_MAP_H10 | 0854h          | Mapper 10            |
| RXU_MAP_L11 | 0858h          | Mapper 11            |
| RXU_MAP_H11 | 085Ch          | Mapper 11            |
| RXU_MAP_L12 | 0860h          | Mapper 12            |
| RXU_MAP_H12 | 0864h          | Mapper 12            |
| RXU_MAP_L13 | 0868h          | Mapper 13            |
| RXU_MAP_H13 | 086Ch          | Mapper 13            |
| RXU_MAP_L14 | 0870h          | Mapper 14            |
| RXU_MAP_H14 | 0874h          | Mapper 14            |
| RXU_MAP_L15 | 0878h          | Mapper 15            |
| RXU_MAP_H15 | 087Ch          | Mapper 15            |
| RXU_MAP_L16 | 0880h          | Mapper 16            |
| RXU_MAP_H16 | 0884h          | Mapper 16            |
| RXU_MAP_L17 | 0888h          | Mapper 17            |
| RXU_MAP_H17 | 088Ch          | Mapper 17            |

## Table 118. Mailbox to Queue Mapping Registers and the Associated RX Mappers



| Register    | Address Offset | Associated RX Mapper |  |  |
|-------------|----------------|----------------------|--|--|
| RXU_MAP_L18 | 0890h          | Mapper 18            |  |  |
| RXU_MAP_H18 | 0894h          | Mapper 18            |  |  |
| RXU_MAP_L19 | 0898h          | Mapper 19            |  |  |
| RXU_MAP_H19 | 089Ch          | Mapper 19            |  |  |
| RXU_MAP_L20 | 08A0h          | Mapper 20            |  |  |
| RXU_MAP_H20 | 08A4h          | Mapper 20            |  |  |
| RXU_MAP_L21 | 08A8h          | Mapper 21            |  |  |
| RXU_MAP_H21 | 08ACh          | Mapper 21            |  |  |
| RXU_MAP_L22 | 08B0h          | Mapper 22            |  |  |
| RXU_MAP_H22 | 08B4h          | Mapper 22            |  |  |
| RXU_MAP_L23 | 08B8h          | Mapper 23            |  |  |
| RXU_MAP_H23 | 08BCh          | Mapper 23            |  |  |
| RXU_MAP_L24 | 08C0h          | Mapper 24            |  |  |
| RXU_MAP_H24 | 08C4h          | Mapper 24            |  |  |
| RXU_MAP_L25 | 08C8h          | Mapper 25            |  |  |
| RXU_MAP_H25 | 08CCh          | Mapper 25            |  |  |
| RXU_MAP_L26 | 08D0h          | Mapper 26            |  |  |
| RXU_MAP_H26 | 08D4h          | Mapper 26            |  |  |
| RXU_MAP_L27 | 08D8h          | Mapper 27            |  |  |
| RXU_MAP_H27 | 08DCh          | Mapper 27            |  |  |
| RXU_MAP_L28 | 08E0h          | Mapper 28            |  |  |
| RXU_MAP_H28 | 08E4h          | Mapper 28            |  |  |
| RXU_MAP_L29 | 08E8h          | Mapper 29            |  |  |
| RXU_MAP_H29 | 08ECh          | Mapper 29            |  |  |
| RXU_MAP_L30 | 08F0h          | Mapper 30            |  |  |
| RXU_MAP_H30 | 08F4h          | Mapper 30            |  |  |
| RXU_MAP_L31 | 08F8h          | Mapper 31            |  |  |
| RXU_MAP_H31 | 08FCh          | Mapper 31            |  |  |

# Table 118. Mailbox to Queue Mapping Registers and the Associated RXMappers (continued)

SEGMENT\_

MAPPING

R/W-0

|                | Figure 113. Mailbox to Queue Mapping Register Pair |                          |            |              |          |        |    |    |   |         |   |    |
|----------------|----------------------------------------------------|--------------------------|------------|--------------|----------|--------|----|----|---|---------|---|----|
| Mailbox to Que | ue Map                                             | ping Register L <i>n</i> | (RXU_MAP_L | .n)          |          |        |    |    |   |         |   |    |
| 31 :           | 30 29                                              |                          |            | 24           | 1 23     |        | 22 | 21 |   |         |   | 16 |
| LETTER_MAS     | (                                                  | MAILB                    | BOX_MASK   |              |          | LETTER |    |    | Ν | IAILBOX |   |    |
| R/W-11         | R/W-11 R/W-111111 R/W-00 R/W                       |                          |            |              | W-000000 |        |    |    |   |         |   |    |
| 15             | 15                                                 |                          |            |              |          |        | 0  |    |   |         |   |    |
|                |                                                    |                          |            | SOUF         | CEID     |        |    |    |   |         |   |    |
|                |                                                    |                          |            | R/W-         | 0000h    |        |    |    |   |         |   |    |
| Mailbox to Que | ue Map                                             | ping Register H n        | (RXU_MAP_H | + <i>n</i> ) |          |        |    |    |   |         |   |    |
| 31             | 31                                                 |                          |            |              |          |        |    |    |   |         |   |    |
| Reserved       |                                                    |                          |            |              |          |        |    |    |   |         |   |    |
|                | R-0                                                |                          |            |              |          |        |    |    |   |         |   |    |
|                |                                                    | 10                       | 9 8        | 7            | 65       |        |    | 2  |   | 1       | 0 |    |

PROMISCUOUS

R/W-0

#### ΤT QUEUE\_ID Reserved Reserved R-0 R/W-01 R-00 R/W-0000

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 119. Mailbox-to-Queue Mapping Register Ln (RXU\_MAP\_Ln) Field Descriptions

| Bit   | Field        | Value           | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30 | LETTER_MASK  | 00b–11b         | Letter mask. Each 0 in this field indicates a don't care bit in the letter number. This allows mapper <i>n</i> to handle a set or range of letter numbers rather than only one.                                                                                                                                                                                                                                         |
| 29–24 | MAILBOX_MASK |                 | Mailbox mask. Each 0 in this field indicates a don't care bit in the mailbox number. This allows mapper $n$ to handle a set or range of mailbox numbers rather than only one.                                                                                                                                                                                                                                           |
|       |              |                 | For a single-segment message:                                                                                                                                                                                                                                                                                                                                                                                           |
|       |              | 000000b-111111b | 6-bit mailbox mask value                                                                                                                                                                                                                                                                                                                                                                                                |
|       |              |                 | For a multi-segment message:                                                                                                                                                                                                                                                                                                                                                                                            |
|       |              | xxxx00b-xxxx11b | 3-bit mailbox mask value                                                                                                                                                                                                                                                                                                                                                                                                |
| 23–22 | LETTER       | 00b–11b         | Letter number. If LETTER_MASK = 11b, this is the only letter number handled by mapper $n$ . If LETTER_MASK is not 11b, mapper $n$ handles the set of letter numbers formed with the mask bit(s).                                                                                                                                                                                                                        |
| 21–16 | MAILBOX      |                 | Mailbox number. If MAILBOX_MASK = 111111b, this is the only mailbox number handled by mapper $n$ . If MAILBOX_MASK is not all 1s, mapper $n$ handles the set of mailbox numbers formed with the mask bit(s).                                                                                                                                                                                                            |
|       |              |                 | For a single-segment message:                                                                                                                                                                                                                                                                                                                                                                                           |
|       |              | 000000b-111111b | 6-bit mailbox number (0 to 63)                                                                                                                                                                                                                                                                                                                                                                                          |
|       |              |                 | For a multi-segment message:                                                                                                                                                                                                                                                                                                                                                                                            |
|       |              | xxxx00b-xxxx11b | 3-bit mailbox number (0 to 3)                                                                                                                                                                                                                                                                                                                                                                                           |
| 15–0  | SOURCEID     | 0000h-FFFFh     | Source identification number. The SOURCEID field is used to indicate which external device has access to mapper <i>n</i> and its corresponding queue. A comparison is performed between the sourceID of the incoming message packet and the SOURCEID field. If the values do not match, an ERROR response is sent to the sender, and the transaction is logged in the logical layer error management capture registers. |

#### Table 120. Mailbox-to-Queue Mapping Register Hn (RXU\_MAP\_Hn) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                      |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------|
| 31–10 | Reserved | 0     | These read-only bits return 0s when read.                                                                                        |
| 9–8   | TT       |       | Transport type                                                                                                                   |
|       |          | 0     | During the sourceID comparison, the incoming sourceID is compared with the 8 LSBs of the SOURCEID field of RXU_MAP_Ln.           |
|       |          | 1     | During the sourceID comparison, the incoming sourceID is compared with all 16 bits of the SOURCEID field of RXU_MAP_L <i>n</i> . |



## Table 120. Mailbox-to-Queue Mapping Register Hn (RXU\_MAP\_Hn) Field Descriptions (continued)

| Bit | Field           | Value | Description                                                                                                                                                                                                             |
|-----|-----------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6 | Reserved        | 0     | These read-only bits return 0s when read.                                                                                                                                                                               |
| 5–2 | QUEUE_ID        | 0–15  | Queue identification number. This field selects which of the 16 RX buffer queues is associated with mapper <i>n</i> .                                                                                                   |
| 1   | PROMISCUOUS     |       | Promiscuous access                                                                                                                                                                                                      |
|     |                 | 0     | Mapper <i>n</i> checks the incoming sourceID (access is restricted to one sender). When determining which transactions to service, the mapper checks the sourceID in addition to the mailbox and letter qualifications. |
|     |                 | 1     | Mapper <i>n</i> ignores the incoming sourceID (access is available to any sender). When determining which transactions to service, the mapper checks only the mailbox and letter qualifications.                        |
| 0   | SEGMENT_MAPPING |       | Segment mapping                                                                                                                                                                                                         |
|     |                 | 0     | Single-segment messaging. Up to 64 mailboxes are available. All six bits of the MAILBOX and MAILBOX_MASK fields of RXU_MAP_L <i>n</i> are valid.                                                                        |
|     |                 | 1     | Multi-segment messaging. Up to 4 mailboxes are available. Only the 2 LSBs of the MAILBOX and MAILBOX_MASK fields of RXU_MAP_L <i>n</i> are valid.                                                                       |

### 5.51 Flow Control Table Entry Register n (FLOW\_CNTLn)

There are sixteen of these registers (see Table 121). FLOW\_CNTLn is shown in Figure 114 and described in Table 122. For additional programming information, see Section 2.3.8.

| Tab         | Table 121. FLOW_CNTLA Registers |  |  |  |
|-------------|---------------------------------|--|--|--|
| Register    | Address Offset                  |  |  |  |
| FLOW_CNTL0  | 0900h                           |  |  |  |
| FLOW_CNTL1  | 0904h                           |  |  |  |
| FLOW_CNTL2  | 0908h                           |  |  |  |
| FLOW_CNTL3  | 090Ch                           |  |  |  |
| FLOW_CNTL4  | 0910h                           |  |  |  |
| FLOW_CNTL5  | 0914h                           |  |  |  |
| FLOW_CNTL6  | 0918h                           |  |  |  |
| FLOW_CNTL7  | 091Ch                           |  |  |  |
| FLOW_CNTL8  | 0920h                           |  |  |  |
| FLOW_CNTL9  | 0924h                           |  |  |  |
| FLOW_CNTL10 | 0928h                           |  |  |  |
| FLOW_CNTL11 | 092Ch                           |  |  |  |
| FLOW_CNTL12 | 0930h                           |  |  |  |
| FLOW_CNTL13 | 0934h                           |  |  |  |
| FLOW_CNTL14 | 0938h                           |  |  |  |
| FLOW_CNTL15 | 093Ch                           |  |  |  |

## Table 121 FLOW CNTL n Registers

### Figure 114. Flow Control Table Entry Register n (FLOW\_CNTLn)

| 31 |              | 18 | 17     | 16 |
|----|--------------|----|--------|----|
|    | Reserved     |    | TT     |    |
|    | R-0          |    | R/W-01 | 1  |
| 15 |              |    |        | 0  |
|    | FLOW_CNTL_ID |    |        |    |
|    | R/W-0000h    |    |        |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 122. Flow Control Table Entry Register n (FLOW\_CNTLn) Field Descriptions

| Bit   | Field        | Value                    | Description                                                                                                                 |  |
|-------|--------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|
| 31–18 | Reserved     | 0                        | These read-only bits return 0s when read.                                                                                   |  |
| 17–16 | TT           | Transfer type for flow n |                                                                                                                             |  |
|       |              | 00b                      | 8-bit destination IDs                                                                                                       |  |
|       |              | 01b                      | 1b 16-bit destination IDs                                                                                                   |  |
|       |              | 1xb                      | Reserved                                                                                                                    |  |
| 15–0  | FLOW_CNTL_ID | 0000h-FFFFh              | Destination ID for flow $n$ . When 8-bit destination IDs are used (TT = 00b), the 8 MSBs of this field are don't care bits. |  |



### 5.52 Device Identity CAR (DEV\_ID)

The device identity CAR (DEV\_ID) is shown in Figure 115 and described in Table 123. Writes have no effect to this register. The values are hard coded and will not change from their reset state.

### Figure 115. Device Identity CAR (DEV\_ID) - Address Offset 1000h

| 31 16          | 0                     |
|----------------|-----------------------|
| DEVICEIDENTITY | DEVICE_VENDORIDENTITY |
| R-0000h        | R-0030h               |

LEGEND: R = Read only; -n = Value after reset

#### Table 123. Device Identity CAR (DEV\_ID) Field Descriptions

| Bit   | Field                 | Value | Description                                             |
|-------|-----------------------|-------|---------------------------------------------------------|
| 31–16 | DEVICEIDENTITY        | 0000h | Identifies the type of device. Vendor specific.         |
| 15–0  | DEVICE_VENDORIDENTITY | 0030h | Device Vendor ID assigned by RapidIO Trade Association. |

### 5.53 Device Information CAR (DEV\_INFO)

The device information CAR (DEV\_INFO) is shown in Figure 116 and described in Table 124. Writes have no effect to this register. The values are hard coded and will not change from their reset state.

### Figure 116. Device Information CAR (DEV\_INFO) - Address Offset 1004h

| 31 |            | 0 |
|----|------------|---|
|    | DEVICEREV  |   |
|    | R-0000000h |   |

LEGEND: R = Read only; -n = Value after reset

#### Table 124. Device Information CAR (DEV\_INFO) Field Descriptions

| Bit  | Field     | Value     | Description                   |
|------|-----------|-----------|-------------------------------|
| 31–0 | DEVICEREV | 00000000h | Vendor supply device revision |



### 5.54 Assembly Identity CAR (ASBLY\_ID)

The assembly identity CAR (ASBLY\_ID) is shown in Figure 117 and described in Table 125. Writes have no effect to this register. The values are hard coded and will not change from their reset state.

### Figure 117. Assembly Identity CAR (ASBLY\_ID) - Address Offset 1008h

| 31 16         | 15 0                |
|---------------|---------------------|
| ASSY_IDENTITY | ASSY_VENDORIDENTITY |
| R-0000h       | R-0030h             |

LEGEND: R = Read only; -n = Value after reset

#### Table 125. Assembly Identity CAR (ASBLY\_ID) Field Descriptions

| Bit   | Field               | Value | Description                                                       |
|-------|---------------------|-------|-------------------------------------------------------------------|
| 31–16 | ASSY_IDENTITY       | 0000h | Assembly identifier. Vendor specific.                             |
| 15–0  | ASSY_VENDORIDENTITY | 0030h | Assembly vendor identifier assigned by RapidIO Trade Association. |



### 5.55 Assembly Information CAR (ASBLY\_INFO)

The assembly information CAR (ASBLY\_INFO) is shown in Figure 118 and described in Table 126. This register is used by SERDES vendor to designate endpoints among the various function blocks of registers. Writes have no effect to this register. The values are hard coded and will not change from their reset state.

#### Figure 118. Assembly Information CAR (ASBLY\_INFO) - Address Offset 100Ch

| 31 16   | 15 0                |
|---------|---------------------|
| ASSYREV | EXTENDEDFEATURESPTR |
| R-0000h | R-0100h             |

LEGEND: R = Read only; -n = Value after reset

#### Table 126. Assembly Information CAR (ASBLY\_INFO) Field Descriptions

| Bit   | Field               | Value | Description                                       |
|-------|---------------------|-------|---------------------------------------------------|
| 31–16 | ASSYREV             | 0000h | Assembly revision level.                          |
| 15–0  | EXTENDEDFEATURESPTR | 0100h | Pointer to first entry in extended features list. |

### 5.56 Processing Element Features CAR (PE\_FEAT)

The processing element features CAR (PE\_FEAT) is shown in Figure 119 and described in Table 127.

### Figure 119. Processing Element Features CAR (PE\_FEAT) - Address Offset 1010h



LEGEND: R = Read only; -n = Value after reset

#### Table 127. Processing Element Features CAR (PE\_FEAT) Field Descriptions

| Bit  | Field                | Value | Description                                                                                                                                                                                                                                                                          |
|------|----------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | BRIDGE               |       | PE can bridge to another interface. Examples are PCI, proprietary processor buses, DRAM, etc.                                                                                                                                                                                        |
| 30   | MEMORY               |       | PE has physically addressable local address space and can be<br>accessed as an endpoint through non-maintenance (i.e.,<br>non-coherent read and write) operations. This local address<br>space may be limited to local configuration Registers, or could be<br>on-chip SRAM, etc.    |
| 29   | PROCESSOR            |       | PE physically contains a local processor or similar device that executes code. A device that bridges to an interface that connects to a processor does not count (see bit 31).                                                                                                       |
| 28   | SWITCH               |       | PE can bridge to another external RapidIO interface. An internal port to a local endpoint does not count as a switch port. For example, a device with two RapidIO ports and a local endpoint is a two port switch, not a three port switch, regardless of the internal architecture. |
| 27–8 | Reserved             | 0     | These read-only bits return 0s when read.                                                                                                                                                                                                                                            |
| 7    | FLOW_CONTROL_SUPPORT |       | PE supports congestion flow control mechanism                                                                                                                                                                                                                                        |
|      |                      | 0     | PE does not support flow control                                                                                                                                                                                                                                                     |
|      |                      | 1     | PE supports flow control                                                                                                                                                                                                                                                             |
| 6    | RETRANSMIT_SUPPRESS  |       | PE supports suppression of error recovery on packet CRC errors.                                                                                                                                                                                                                      |
|      |                      | 0     | PE does not support suppression                                                                                                                                                                                                                                                      |
|      |                      | 1     | PE supports suppression                                                                                                                                                                                                                                                              |
| 5    | CRF_SUPPORT          |       | This bit indicates PE support for the Critical Request Flow (CRF) Function.                                                                                                                                                                                                          |
|      |                      | 0     | PE does not support CRF Function                                                                                                                                                                                                                                                     |
|      |                      | 1     | PE supports CRF Function                                                                                                                                                                                                                                                             |
| 4    | LARGE_SUPPORT        |       | Support of common transport large systems.                                                                                                                                                                                                                                           |
|      |                      | 0     | PE does not support common transport large systems                                                                                                                                                                                                                                   |
|      |                      | 1     | PE supports common transport large systems                                                                                                                                                                                                                                           |
| 3    | EXTENDED_FEATURES    |       | PE has extended features list; the extended features pointer is valid.                                                                                                                                                                                                               |

| Bit | Field                       | Value | Description                                                                                                                                                                                    |
|-----|-----------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2–0 | EXTENDED_ADDRESSING_SUPPORT |       | Indicates the number address bits supported by the PE both as a source and target of an operation. All PEs shall at minimum support 34 bit addresses. Encodings other than below are reserved. |
|     |                             | 001b  | PE supports 34 bit addresses                                                                                                                                                                   |
|     |                             | 011b  | PE supports 50 and 34 bit addresses                                                                                                                                                            |
|     |                             | 101b  | PE supports 66 and 34 bit addresses                                                                                                                                                            |
|     |                             | 111b  | PE supports 66, 50 and 34 bit addresses                                                                                                                                                        |
|     |                             | Other | Reserved                                                                                                                                                                                       |

### Table 127. Processing Element Features CAR (PE\_FEAT) Field Descriptions (continued)

### 5.57 Source Operations CAR (SRC\_OP)

The source operations CAR (SRC\_OP) is shown in Figure 120 and described in Table 128.

### Figure 120. Source Operations CAR (SRC\_OP) - Address Offset 1018h

| 31                 | 31 24             |                  |                     |           |                |          |                          |  |  |
|--------------------|-------------------|------------------|---------------------|-----------|----------------|----------|--------------------------|--|--|
|                    | Reserved          |                  |                     |           |                |          |                          |  |  |
|                    |                   |                  | R                   | -0        |                |          |                          |  |  |
| 23                 | 23 18 17 16       |                  |                     |           |                |          |                          |  |  |
|                    |                   | Re               | eserved             |           |                | IMPLMN   | IT_DEFINED_2             |  |  |
|                    | R-0 R-00          |                  |                     |           |                |          | R-00                     |  |  |
| 15                 | 14                | 13               | 12                  | 11        | 10             | 9        | 8                        |  |  |
| READ               | WRITE             | STREAM_<br>WRITE | WRITE_WITH_<br>RESP | DATA_MESS | DOORBELL       | Reserved | ATOMIC_TEST_<br>AND_SWAP |  |  |
| R-0                | R-0               | R-0              | R-0                 | R-0       | R-0            | R-0      | R-0                      |  |  |
| 7                  | 6                 | 5                | 4                   | 3         | 2              | 1        | 0                        |  |  |
| ATOMIC_<br>INCRMNT | ATOMIC_<br>DCRMNT | ATOMIC_<br>SET   | ATOMIC_<br>CLEAR    | Reserved  | PORT_<br>WRITE | IMPLMN   | IT_DEFINED_1             |  |  |
| R-0                | R-0               | R-0              | R-0                 | R-0       | R-1            |          | R-00                     |  |  |

LEGEND: R = Read only; -n = Value after reset

#### Table 128. Source Operations CAR (SRC\_OP) Field Descriptions

| Bit   | Field                    | Value | Description                                      |
|-------|--------------------------|-------|--------------------------------------------------|
| 31–18 | Reserved                 | 0     | These read-only bits return 0s when read.        |
| 17–16 | IMPLMNT_DEFINED_2        |       | Defined by the device implementation             |
| 15    | READ                     |       | PE can support a read operation                  |
| 14    | WRITE                    |       | PE can support a write operation                 |
| 13    | STREAM_WRITE             |       | PE can support a streaming-write operation       |
| 12    | WRITE_WITH_RESP          |       | PE can support a write-with-response operation   |
| 11    | DATA_MESS                |       | PE can support a data message operation          |
| 10    | DOORBELL                 |       | PE can support a doorbell operation              |
| 9     | Reserved                 | 0     | This read-only bit returns 0 when read.          |
| 8     | ATOMIC_TEST_<br>AND_SWAP |       | PE can support an atomic test-and-swap operation |
| 7     | ATOMIC_INCRMNT           |       | PE can support an atomic increment operation     |
| 6     | ATOMIC_DCRMNT            |       | PE can support an atomic decrement operation     |
| 5     | ATOMIC_SET               |       | PE can support an atomic set operation           |
| 4     | ATOMIC_CLEAR             |       | PE can support an atomic clear operation         |
| 3     | Reserved                 | 0     | This read-only bit returns 0 when read.          |
| 2     | PORT_WRITE               |       | PE can support a port-write generation           |
| 1–0   | IMPLMNT_DEFINED_1        |       | Defined by the device implementation             |

### 5.58 Destination Operations CAR (DEST\_OP)

The destination operations CAR (DEST\_OP) is shown in Figure 121 and described in Table 129.

### Figure 121. Destination Operations CAR (DEST\_OP) - Address Offset 101Ch

| 31                 | 31 24             |                |                     |           |                |          |                          |
|--------------------|-------------------|----------------|---------------------|-----------|----------------|----------|--------------------------|
|                    |                   |                | Rese                | rved      |                |          |                          |
|                    |                   |                | R-                  | 0         |                |          |                          |
| 23                 |                   |                |                     |           | 18             | 17       | 16                       |
|                    |                   | Rese           | erved               |           |                | IMPLMN   | T_DEFINED_2              |
|                    | R-0 R-00          |                |                     |           |                |          | R-00                     |
| 15                 | 14                | 13             | 12                  | 11        | 10             | 9        | 8                        |
| READ               | WRITE             | STREAM_WRITE   | WRITE_WITH_<br>RESP | DATA_MESS | DOORBELL       | Reserved | ATOMIC_TEST_<br>AND_SWAP |
| R-0                | R-0               | R-0            | R-0                 | R-0       | R-0            | R-0      | R-0                      |
| 7                  | 6                 | 5              | 4                   | 3         | 2              | 1        | 0                        |
| ATOMIC_<br>INCRMNT | ATOMIC_<br>DCRMNT | ATOMIC_<br>SET | ATOMIC_<br>CLEAR    | Reserved  | PORT_<br>WRITE | IMPLMN   | T_DEFINED_1              |
| R-0                | R-0               | R-0            | R-0                 | R-0       | R-1            |          | R-00                     |

LEGEND: R = Read only; -n = Value after reset

#### Table 129. Destination Operations CAR (DEST\_OP) Field Descriptions

| Bit   | Field                | Value | Description                                      |
|-------|----------------------|-------|--------------------------------------------------|
| 31–18 | Reserved             | 0     | These read-only bits return 0s when read.        |
| 17–16 | IMPLMNT_DEFINED_2    |       | Defined by the device implementation             |
| 15    | READ                 |       | PE can support a read operation                  |
| 14    | WRITE                |       | PE can support a write operation                 |
| 13    | STREAM_WRITE         |       | PE can support a streaming-write operation       |
| 12    | WRITE_WITH_RESP      |       | PE can support a write-with-response operation   |
| 11    | DATA_MESS            |       | PE can support a data message operation          |
| 10    | DOORBELL             |       | PE can support a doorbell operation              |
| 9     | Reserved             | 0     | This read-only bit returns 0 when read.          |
| 8     | ATOMIC_TEST_AND_SWAP |       | PE can support an atomic test-and-swap operation |
| 7     | ATOMIC_INCRMNT       |       | PE can support an atomic increment operation     |
| 6     | ATOMIC_DCRMNT        |       | PE can support an atomic decrement operation     |
| 5     | ATOMIC_SET           |       | PE can support an atomic set operation           |
| 4     | ATOMIC_CLEAR         |       | PE can support an atomic clear operation         |
| 3     | Reserved             | 0     | This read-only bit returns 0 when read.          |
| 2     | PORT_WRITE           |       | PE can support a port-write generation           |
| 1–0   | IMPLMNT_DEFINED_1    |       | Defined by the device implementation             |



### 5.59 Processing Element Logical Layer Control CSR (PE\_LL\_CTL)

The processing element logical layer control CSR (PE\_LL\_CTL) is shown in Figure 122 and described in Table 130.

### Figure 122. Processing Element Logical Layer Control CSR (PE\_LL\_CTL) - Address Offset 104Ch

| 31 |          |      | 16                          |
|----|----------|------|-----------------------------|
|    | Reserved |      |                             |
|    | R-0      |      |                             |
| 15 |          | 3 2  | 0                           |
|    | Reserved | ADDF | ENDED_<br>RESSING_<br>NTROL |
|    | R-0      | R/   | /W-001                      |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

#### Table 130. Processing Element Logical Layer Control CSR (PE\_LL\_CTL) Field Descriptions

| Bit  | Field                       | Value | Description                                                                                                                                              |
|------|-----------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–3 | Reserved                    | 0     | These read-only bits return 0s when read.                                                                                                                |
| 2–0  | EXTENDED_ADDRESSING_CONTROL |       | Controls the number of address bits generated by the PE as a source and processed by the PE as the target of an operation. All other encodings reserved. |
|      |                             | 001b  | PE supports 34 bit addresses                                                                                                                             |
|      |                             | 010b  | PE supports 50 bit addresses                                                                                                                             |
|      |                             | 100b  | PE supports 66 bit addresses                                                                                                                             |
|      |                             | Other | Reserved                                                                                                                                                 |

### 5.60 Local Configuration Space Base Address 0 CSR (LCL\_CFG\_HBAR)

The local configuration space base address 0 CSR (LCL\_CFG\_HBAR) is shown in Figure 123 and described in Table 131.

# Figure 123. Local Configuration Space Base Address 0 CSR (LCL\_CFG\_HBAR) - Address Offset 1058h

 31
 30
 0

 Reserved
 LCSBA
 0

 R-0
 R-00000000h
 0

LEGEND: R = Read only; -n = Value after reset

#### Table 131. Local Configuration Space Base Address 0 CSR (LCL\_CFG\_HBAR) Field Descriptions

| Bit  | Field    | Value                        | Description                                                                                                                                                                                                                                         |
|------|----------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | Reserved | 0                            | These read-only bits return 0s when read.                                                                                                                                                                                                           |
| 30–0 | LCSBA    | 00000000h<br>to<br>FFFFFFFFh | Bits 30 to 15 are reserved for 34-bit addresses, reserved for 50-bit addresses, and bits 66 to 51 of a 66-bit address.<br>Bits 14 to 0 are reserved for 34-bit addresses, bits 50 to 36 of a 50-bit address, and bits 50 to 36 of a 66-bit address. |



### 5.61 Local Configuration Space Base Address 1 CSR (LCL\_CFG\_BAR)

The local configuration space base address 1 CSR (LCL\_CFG\_BAR) is shown in Figure 124 and described in Table 132.

# Figure 124. Local Configuration Space Base Address 1 CSR (LCL\_CFG\_BAR) - Address Offset 105Ch

31 0 LCSBA

R-0000000h

LEGEND: R = Read only; -n = Value after reset

#### Table 132. Local Configuration Space Base Address 1 CSR (LCL\_CFG\_BAR) Field Descriptions

| Bit  | Field | Value                        | Description                                                                                                                                                                                                                        |
|------|-------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | LCSBA | 00000000h<br>to<br>FFFFFFFFh | Bit 31 is reserved for 34-bit addresses, bit 35 of a 50-bit address, and bit 35 of a 66-bit address.<br>Bits 30 to 0 are bits 34 to 3 of a 34-bit address, bits 35 to 3 of a 50-bit address, and bits 35 to 3 of a 66-bit address. |

## 5.62 Base Device ID CSR (BASE\_ID)

The base device ID CSR (BASE\_ID) is shown in Figure 125 and described in Table 133.

### Figure 125. Base Device ID CSR (BASE\_ID) - Address Offset 1060h

| 31 | 24 23    |                     |   |  |
|----|----------|---------------------|---|--|
|    | Reserved | BASE_DEVICEID       |   |  |
|    | R-00h    | R/W-FFh             |   |  |
| 15 |          |                     | 0 |  |
|    |          | LARGE_BASE_DEVICEID |   |  |
|    |          |                     |   |  |

R/W-FFFFh

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 133. Base Device ID CSR (BASE\_ID) Field Descriptions

| Bit   | Field               | Value       | Description                                                                                                                                   |
|-------|---------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24 | Reserved            | 00h         | These read-only bits return 0s when read.                                                                                                     |
| 23–16 | BASE_DEVICEID       | 00h–FFh     | This is the base ID of the device in small common transport system (endpoints only).                                                          |
| 15–0  | LARGE_BASE_DEVICEID | 0000h-FFFFh | This is the base ID of the device in a large common transport system (Only valid for endpoints, and if bit 4 of the PE_FEAT Register is set). |



SRIO Registers

### 5.63 Host Base Device ID Lock CSR (HOST\_BASE\_ID\_LOCK)

See Section 2.4.2 of the RapidIO *Common Transport Specification* for a description of this register. It provides a lock function that is write-once/reset-able. The host base device ID lock CSR (HOST\_BASE\_ID\_LOCK) is shown in Figure 126 and described in Table 134.

#### Figure 126. Host Base Device ID Lock CSR (HOST\_BASE\_ID\_LOCK) - Address Offset 1068h

| 31 16    | 15 0               |
|----------|--------------------|
| Reserved | HOST_BASE_DEVICEID |
| R-0000h  | R/W-FFFFh          |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 134. Host Base Device ID Lock CSR (HOST\_BASE\_ID\_LOCK) Field Descriptions

| Bit   | Field              | Value       | Description                                                       |
|-------|--------------------|-------------|-------------------------------------------------------------------|
| 31–16 | Reserved           | 0000h       | These read-only bits return 0s when read.                         |
| 15–0  | HOST_BASE_DEVICEID | 0000h-FFFFh | This is the base ID for the Host PE that is initializing this PE. |



### 5.64 Component Tag CSR (COMP\_TAG)

The component Tag CSR (COMP\_TAG) is shown in Figure 127 and described in Table 135.

### Figure 127. Component Tag CSR (COMP\_TAG) - Address Offset 106Ch

| 31 |               | 0 |
|----|---------------|---|
|    | COMPONENT_TAG |   |
|    | R/W-0000000h  |   |

LEGEND: R/W = Read/Write; -*n* = Value after reset

#### Table 135. Component Tag CSR (COMP\_TAG) Field Descriptions

| Bit  | Field         | Value                        | Description                                                                       |
|------|---------------|------------------------------|-----------------------------------------------------------------------------------|
| 31–0 | COMPONENT_TAG | 00000000h<br>to<br>FFFFFFFFh | Software defined component tag for the PE. Useful for devices without device IDs. |



SRIO Registers

### 5.65 1x/4x LP Serial Port Maintenance Block Header Register (SP\_MB\_HEAD)

The 1x/4x LP\_Serial port maintenance block header register (SP\_MB\_HEAD) is shown in Figure 128 and described in Table 136.

#### Figure 128. 1x/4x LP\_Serial Port Maintenance Block Header Register (SP\_MB\_HEAD) - Address Offset 1100h

| 31 16   | 15 0    |
|---------|---------|
| EF_PTR  | EF_ID   |
| R-1000h | R-0001h |

LEGEND: R = Read only; -n = Value after reset

#### Table 136. 1x/4x LP\_Serial Port Maintenance Block Header Register (SP\_MB\_HEAD) Field Descriptions

| Bit   | Field  | Value | Description                                                          |  |
|-------|--------|-------|----------------------------------------------------------------------|--|
| 31–16 | EF_PTR |       | Hard wired pointer to the next block in the data structure.          |  |
| 15–0  | EF_ID  |       | Hard wired extended features ID.                                     |  |
|       |        | 0001h | General endpoint device                                              |  |
|       |        | 0002h | General endpoint device with software assisted error recovery option |  |
|       |        | 0003h | Switch                                                               |  |

### 5.66 Port Link Time-Out Control CSR (SP\_LT\_CTL)

The port link time-out control CSR (SP\_LT\_CTL) is shown in Figure 129 and described in Table 137.

### Figure 129. Port Link Time-Out Control CSR (SP\_LT\_CTL) - Address Offset 1120h

| 31            |           |          |   |
|---------------|-----------|----------|---|
| TIME          | OUT_VALUE |          |   |
| R/            | N-FFFFFFh |          |   |
|               | 8 7       |          | 0 |
| TIMEOUT_VALUE |           | Reserved |   |
| R/W-FFFFFh    |           | R-00h    |   |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 137. Port Link Timeout Control CSR (SP\_LT\_CTL) Field Descriptions

| Bit  | Field         | Value   | Description                                                                                                                                                                                                                                                                                    |
|------|---------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8 | TIMEOUT_VALUE |         | Timeout value for all ports on the device. This timeout is for link events such as sending a packet to receiving the corresponding ACK. Max value represents 3-6 seconds. Timeout duration = 205 ns * Timeout Value; where Timeout value is the decimal representation of this register value. |
|      |               | FFFFFh  | 3.4 s                                                                                                                                                                                                                                                                                          |
|      |               | 0FFFFFh | 215 ms                                                                                                                                                                                                                                                                                         |
|      |               | 00FFFFh | 13.4 ms                                                                                                                                                                                                                                                                                        |
|      |               | 000FFFh | 839.5 μs                                                                                                                                                                                                                                                                                       |
|      |               | 0000FFh | 52.3 μs                                                                                                                                                                                                                                                                                        |
|      |               | 00000Fh | 3.1 μs                                                                                                                                                                                                                                                                                         |
|      |               | 000001h | 205 ns for simulation only                                                                                                                                                                                                                                                                     |
|      |               | 000000h | Timer disabled                                                                                                                                                                                                                                                                                 |
| 7–0  | Reserved      | 00h     | These read-only bits return 0s when read.                                                                                                                                                                                                                                                      |



SRIO Registers

### 5.67 Port Response Time-Out Control CSR (SP\_RT\_CTL)

The port response time-out control CSR (SP\_RT\_CTL) is shown in Figure 130 and described in Table 138 For additional programming information, see Section 2.3.3.3 and Section 2.3.3.

### Figure 130. Port Response Time-Out Control CSR (SP\_RT\_CTL) - Address Offset 1124h

| 31            |               |
|---------------|---------------|
|               | TIMEOUT_VALUE |
|               | RW-FFFFFh     |
|               | 8 7 0         |
| TIMEOUT_VALUE | Reserved      |
| RW-FFFFFh     | R-00h         |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 138. Port Response Time-Out Control CSR (SP\_RT\_CTL) Field Descriptions

| Bit  | Field         | Value                    | Description                                                                                                                                                                                                                                                   |
|------|---------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8 | TIMEOUT_VALUE | 000000h<br>to<br>FFFFFFh | Timeout value for all ports on the device. This timeout is for sending a packet to receiving the corresponding response packet. Max value represents 3 to 6 seconds. The timeout duration can be expressed as:                                                |
|      |               |                          | Timeout = 15 x ((Prescale Value + 1) x DMA Clock Period x Timeout Value)                                                                                                                                                                                      |
|      |               |                          | where Prescale value is set in PER_SET_CNTL (offset 0020h) and the Timeout value is the decimal representation of this register value. For example, given a 400-MHz DMA, a Prescale Value of 4, and a Timeout Value of FFFFFh, the Timeout duration would be: |
|      |               |                          | Timeout = 15 x ((4 + 1) x 2.5 ns x 16777216) = 3.15 s                                                                                                                                                                                                         |
| 7–0  | Reserved      | 00h                      | These read-only bits return 0s when read.                                                                                                                                                                                                                     |

### 5.68 Port General Control CSR (SP\_GEN\_CTL)

The port general control CSR (SP\_GEN\_CTL) is shown in Figure 131 and described in Table 139.

### Figure 131. Port General Control CSR (SP\_GEN\_CTL) - Address Offset 113Ch

| 31    | 30                | 29         | 28 0     |
|-------|-------------------|------------|----------|
| HOST  | MASTER_<br>ENABLE | DISCOVERED | Reserved |
| R/W-0 | R/W-0             | R/W-0      | R-0      |

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

### Table 139. Port General Control CSR (SP\_GEN\_CTL) Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                                    |
|------|---------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | HOST          |       | A host device is a device that is responsible for system exploration, initialization, and maintenance. Agent or slave devices are typically initialized by Host devices.       |
|      |               | 0     | Agent or Slave device                                                                                                                                                          |
|      |               | 1     | Host device                                                                                                                                                                    |
| 30   | MASTER_ENABLE |       | The Master Enable bit controls whether or not a device is allowed to issue requests into the system. If the Master Enable is not set, the device may only respond to requests. |
|      |               | 0     | Processing element cannot issue requests                                                                                                                                       |
|      |               | 1     | Processing element can issue requests                                                                                                                                          |
| 29   | DISCOVERED    |       | This device has been located by the processing element responsible for system configuration.                                                                                   |
|      |               | 0     | The device has not been previously discovered                                                                                                                                  |
|      |               | 1     | The device has been discovered by another processing element                                                                                                                   |
| 28–0 | Reserved      | 0     | These read-only bits return 0s when read.                                                                                                                                      |



### 5.69 Port Link Maintenance Request CSR n (SPn\_LM\_REQ)

Each of the four ports is supported by a register of this type (see Table 140). SP*n*\_LM\_REQ is shown in Figure 132 and described in Table 141.

| Table 140. SPn_LM_REQ Registers and the Associated Ports |                |                 |  |  |  |
|----------------------------------------------------------|----------------|-----------------|--|--|--|
| Register                                                 | Address Offset | Associated Port |  |  |  |
| SP0_LM_REQ                                               | 1140h          | Port 0          |  |  |  |
| SP1_LM_REQ                                               | 1160h          | Port 1          |  |  |  |
| SP2_LM_REQ                                               | 1180h          | Port 2          |  |  |  |
| SP3_LM_REQ                                               | 11A0h          | Port 3          |  |  |  |

#### Table 140 CD d th . ..... 4 D ----

#### Figure 132. Port Link Maintenance Request CSR n (SPn\_LM\_REQ)

| 31       | 3 2 0   |
|----------|---------|
| Reserved | COMMAND |
| R-0      | R/W-000 |
|          |         |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 141. Port Link Maintenance Request CSR n (SPn\_LM\_REQ) Field Descriptions

| Bit  | Field    | Value     | Description                                                                                                                                                                                                        |
|------|----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–3 | Reserved | 0         | These read-only bits return 0s when read.                                                                                                                                                                          |
| 2–0  | COMMAND  | 000b–111b | A write to this register generates a link-request control symbol on the corresponding port interface. Command to be sent in the link-request control symbol. When read, this field returns the last written value. |

### 5.70 Port Link Maintenance Response CSR n (SPn\_LM\_RESP)

Each of the four ports is supported by a register of this type (see Table 142). The port link maintenance response CSR n (SPn\_LM\_RESP) is shown in Figure 133 and described in Table 143.

| Table 142. SPn_ | LM_RESP Registers and the Assoc | iated Ports |
|-----------------|---------------------------------|-------------|
|-----------------|---------------------------------|-------------|

| Register    | Address Offset | Associated Port |  |
|-------------|----------------|-----------------|--|
| SP0_LM_RESP | 1144h          | Port 0          |  |
| SP1_LM_RESP | 1164h          | Port 1          |  |
| SP2_LM_RESP | 1184h          | Port 2          |  |
| SP3_LM_RESP | 11A4h          | Port 3          |  |

### Figure 133. Port Link Maintenance Response CSR *n* (SP*n*\_LM\_RESP)

| 31 30              |          |              |             | 16 |
|--------------------|----------|--------------|-------------|----|
| RESPONSE_<br>VALID | Reserved |              |             |    |
| R-0                |          | R-0          |             |    |
| 15                 | 10 9     | 10 9 5 4     |             |    |
| Reserved           |          | ACKID_STATUS | LINK_STATUS |    |
| R-0                |          | R-0 R-       |             |    |

LEGEND: R = Read only; -n = Value after reset

### Table 143. Port Link Maintenance Response CSR n (SPn\_LM\_RESP) Field Descriptions

| Bit   | Field          | Value         | Description                                                                                                                                                                                                                                                                                        |
|-------|----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RESPONSE_VALID |               | If the link-request causes a link-response, this bit indicates that the link-response has been received and the status fields are valid. If the link-request does not cause a link-response, this bit indicates that the link-request has been transmitted. This bit automatically clears on read. |
| 30–10 | Reserved       | 0             | These read-only bits return 0s when read.                                                                                                                                                                                                                                                          |
| 9–5   | ACKID_STATUS   | 00000b-11111b | AckID status field from the link-response control symbol                                                                                                                                                                                                                                           |
| 4–0   | LINK_STATUS    | 00000b-11111b | Link status field from the link-response control symbol                                                                                                                                                                                                                                            |



### 5.71 Port Local AckID Status CSR n (SPn\_ACKID\_STAT)

Each of the four ports is supported by a register of this type (see Table 144). The port local ackID status CSR n (SPn\_ACKID\_STAT) is shown in Figure 134 and described in Table 145.

### Table 144. SPn\_ACKID\_STAT Registers and the Associated Ports

| Register       | Address Offset | Associated Port |  |
|----------------|----------------|-----------------|--|
| SP0_ACKID_STAT | 1148h          | Port 0          |  |
| SP1_ACKID_STAT | 1168h          | Port 1          |  |
| SP2_ACKID_STAT | 1188h          | Port 2          |  |
| SP3_ACKID_STAT | 11A8h          | Port 3          |  |

#### Figure 134. Port Local AckID Status CSR n (SPn\_ACKID\_STAT)

| 31 | 2        | 29 28 |                 | 24 23 |          |                | 16 |
|----|----------|-------|-----------------|-------|----------|----------------|----|
|    | Reserved | I     | INBOUND_ACKID   |       | Reserved |                |    |
|    | R-0      |       | R/W-0           |       |          | R-0            |    |
| 15 | 1        | 3 12  |                 | 87    |          | 3 4            | 0  |
|    | Reserved | OU    | ISTANDING_ACKID |       | Reserved | OUTBOUND_ACKID |    |
|    | R-0      |       | R/W-0           |       | R-0      | R/W-0          |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 145. Port Local AckID Status CSR n (SPn\_ACKID\_STAT) Field Descriptions

| Bit   | Field             | Value         | Description                                                                                                                                                                                  |
|-------|-------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–29 | Reserved          | 0             | These read-only bits return 0s when read.                                                                                                                                                    |
| 28–24 | INBOUND_ACKID     | 00000b-11111b | Input port next expected ackID value                                                                                                                                                         |
| 23–13 | Reserved          | 0             | These read-only bits return 0s when read.                                                                                                                                                    |
| 12–8  | OUTSTANDING_ACKID | 00000b–11111b | Output port unacknowledged ackID status. Next expected acknowledge<br>control symbol ackID field that indicates the ackID value expected in the<br>next received acknowledge control symbol. |
| 7–5   | Reserved          | 0             | These read-only bits return 0s when read.                                                                                                                                                    |
| 4–0   | OUTBOUND_ACKID    | 00000b-11111b | Output port next transmitted ackID value. Software writing this value can force retransmission of outstanding unacknowledged packets in order to manually implement error recovery.          |

### 5.72 Port Error and Status CSR n (SPn\_ERR\_STAT)

Each of the four ports is supported by a register of this type (see Table 146). The port error and status CSR n (SPn\_ERR\_STAT) is shown in Figure 135 and described in Table 147.

### Table 146. SPn\_ERR\_STAT Registers and the Associated Ports

| Register     | Address Offset | Associated Port |  |
|--------------|----------------|-----------------|--|
| SP0_ERR_STAT | 1158h          | Port 0          |  |
| SP1_ERR_STAT | 1178h          | Port 1          |  |
| SP2_ERR_STAT | 1198h          | Port 2          |  |
| SP3_ERR_STAT | 11B8h          | Port 3          |  |

| 31            |          |                             | 27                 | 7 26                     | 25                       | 24                          |
|---------------|----------|-----------------------------|--------------------|--------------------------|--------------------------|-----------------------------|
|               | Reserved |                             |                    | OUTPUT_<br>PKT_<br>DROP  | OUTPUT_<br>FLD_<br>ENC   | OUTPUT_<br>DEGRD_<br>ENC    |
|               | R-0      |                             |                    | R/W-0                    | R/W-0                    | R/W-0                       |
| 23            | 21       | 20                          | 19                 | 18                       | 17                       | 16                          |
| Reserved      |          | OUTPUT_<br>RETRY_<br>ENC    | OUTPUT_<br>RETRIED | OUTPUT_<br>RETRY_<br>STP | OUTPUT_<br>ERROR_<br>ENC | OUTPUT_<br>ERROR_<br>STP    |
| R-0           |          | R/W-0                       | R-0                | R-0                      | R/W-0                    | R-0                         |
| 15            |          |                             | 1                  | 1 10                     | 9                        | 8                           |
|               | Reserved |                             |                    | INPUT_<br>RETRY_<br>STP  | INPUT_<br>ERROR_<br>ENC  | INPUT_<br>ERROR_<br>STP     |
|               | R-0      |                             |                    | R-0                      | R/W-0                    | R-0                         |
|               | -        |                             |                    |                          |                          |                             |
| 7             | 5        | 4                           | 3                  | 2                        | 1                        | 0                           |
| 7<br>Reserved | 5        | 4<br>PORT_<br>WRITE_<br>PND | 3<br>Reserved      | 2<br>PORT_<br>ERROR      | 1<br>PORT_<br>OK         | 0<br>PORT_<br>UNINITIALIZED |

### Figure 135. Port Error and Status CSR n (SPn\_ERR\_STAT)

LEGEND: R/W = Read/Write; R = Read only; -*n* = Value after reset

### Table 147. Port Error and Status CSR n (SPn\_ERR\_STAT) Field Descriptions

| Bit   | Field            | Value                                       | Description                                                                                                                                                  |  |
|-------|------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31–27 | Reserved         | 0 These read-only bits return 0s when read. |                                                                                                                                                              |  |
| 26    | OUTPUT_PKT_DROP  |                                             | Output packet drop (switch devices only)                                                                                                                     |  |
|       |                  | 0                                           | The output port has not discarded a packet.                                                                                                                  |  |
|       |                  | 1                                           | The output port has discarded a packet.                                                                                                                      |  |
| 25    | OUTPUT_FLD_ENC   |                                             | Output failed condition encountered. Once set, the OUTPUT_FLD_ENC bit remains set until software writes a 1 to it.                                           |  |
|       |                  | 0                                           | The output port has not encountered a failed condition.                                                                                                      |  |
|       |                  | 1                                           | The output port has encountered a failed condition. The failed port error threshold has been reached in the Port <i>n</i> Error Rate Threshold Register.     |  |
| 24    | OUTPUT_DEGRD_ENC |                                             | Output degraded condition encountered. Once set, the OUTPUT_DEGRD_ENC bit remains set until software writes a 1 to it.                                       |  |
|       |                  | 0                                           | The output port has not encountered a degraded condition.                                                                                                    |  |
|       |                  | 1                                           | The output port has encountered a degraded condition. The degraded port error threshold has been reached in the Port <i>n</i> Error Rate Threshold Register. |  |



### Table 147. Port Error and Status CSR n (SPn\_ERR\_STAT) Field Descriptions (continued)

| Bit   | Field            | Value | Description                                                                                                                                                                                                              |
|-------|------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–21 | Reserved         | 0     | These read-only bits return 0s when read.                                                                                                                                                                                |
| 20    | OUTPUT_RETRY_ENC |       | Output retry condition encountered. Once set, the OUTPUT_RETRY_ENC bit remains set until software writes a 1 to it.                                                                                                      |
|       |                  | 0     | The output port has not encountered a retry condition.                                                                                                                                                                   |
|       |                  | 1     | The output port has encountered a retry condition. This bit is set when bit 18 is set.                                                                                                                                   |
| 19    | OUTPUT_RETRIED   |       | Output retried. OUTPUT_RETRIED is a read-only bit.                                                                                                                                                                       |
|       |                  | 0     | The output port has not received a packet-retry control symbol.                                                                                                                                                          |
|       |                  | 1     | The output port has received a packet-retry control symbol and cannot make forward progress. This bit is set when bit 18 is set and is cleared when a packet-accepted or packet-not-accepted control symbol is received. |
| 18    | OUTPUT_RETRY_STP |       | Output retry-stopped state. OUTPUT_RETRY_STP is a read-only bit.                                                                                                                                                         |
|       |                  | 0     | The output port has not received a packet-retry control symbol and/or is not in the "output retry-stopped" state.                                                                                                        |
|       |                  | 1     | The output port has received a packet-retry control symbol and is in the "output retry-stopped" state.                                                                                                                   |
| 17    | OUTPUT_ERROR_ENC |       | Output transmission error encountered. Once set, the OUTPUT_ERROR_ENC bit remains set until software writes a 1 to it.                                                                                                   |
|       |                  | 0     | The output port has not encountered a transmission error.                                                                                                                                                                |
|       |                  | 1     | The output port has encountered (and possibly recovered from) a transmission error. This bit is set when bit 16 is set.                                                                                                  |
| 16    | OUTPUT_ERROR_STP |       | Output error-stopped. OUTPUT_ERROR_STP is a read-only bit.                                                                                                                                                               |
|       |                  | 0     | The output port is not in the "output error-stopped" state.                                                                                                                                                              |
|       |                  | 1     | The output port is in the "output error-stopped" state.                                                                                                                                                                  |
| 15–11 | Reserved         | 0     | These read-only bits return 0s when read.                                                                                                                                                                                |
| 10    | INPUT_RETRY_STP  |       | Input retry-stopped state. INPUT_RETRY_STP is a read-only bit.                                                                                                                                                           |
|       |                  | 0     | The input port is not in the "input retry-stopped" state.                                                                                                                                                                |
|       |                  | 1     | The input port is in the "input retry-stopped" state.                                                                                                                                                                    |
| 9     | INPUT_ERROR_ENC  |       | Input port transmission error encountered. Once set, the INPUT_ERROR_ENC bit remains set until software writes a 1 to it.                                                                                                |
|       |                  | 0     | The input port has not encountered a transmission error.                                                                                                                                                                 |
|       |                  | 1     | The input port has encountered (and possibly recovered from) a transmissio error. This bit is set when bit 8 is set.                                                                                                     |
| 8     | INPUT_ERROR_STP  |       | Input error-stopped state. INPUT_ERROR_STP is a read-only bit.                                                                                                                                                           |
|       |                  | 0     | The input port is not in the "input error-stopped" state.                                                                                                                                                                |
|       |                  | 1     | The input port is in the "input error-stopped" state.                                                                                                                                                                    |
| 7–5   | Reserved         | 0     | These read-only bits return 0s when read.                                                                                                                                                                                |
| 4     | PORT_WRITE_PND   |       | Port-write pending. This bit is only valid if the device is capable of issuing a maintenance port-write transaction. Once set, the PORT_WRITE_PND bit remains set until software writes a 1 to it.                       |
|       |                  | 0     | The port has not encountered a condition which required it to initiate a Maintenance Port-write operation.                                                                                                               |
|       |                  | 1     | The port has encountered a condition which required it to initiate a Maintenance Port-write operation.                                                                                                                   |
| 3     | Reserved         | 0     | This read-only bit returns 0 when read.                                                                                                                                                                                  |
| 2     | PORT_ERROR       |       | Port unrecoverable error. Once set, the PORT_ERROR bit remains set until software writes a 1 to it.                                                                                                                      |
|       |                  | 0     | The input or output port has not encountered an error from which hardware was unable to recover.                                                                                                                         |
|       |                  | 1     | The input or output port has encountered an error from which hardware was unable to recover.                                                                                                                             |

| Bit | Field              | Value | Description                                                                                                                                    |
|-----|--------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | PORT_OK            |       | Port OK. This bit is a read-only bit.                                                                                                          |
|     |                    | 0     | Port not-OK condition                                                                                                                          |
|     |                    | 1     | Port OK condition. The input and output ports are initialized, and the port is exchanging error-free control symbols with the attached device. |
| 0   | PORT_UNINITIALIZED |       | Port uninitialized. PORT_UNINITIALIZED is a read-only bit. This bit and the PORT_OK bit are mutually exclusive.                                |
|     |                    | 0     | Input and output ports are initialized.                                                                                                        |
|     |                    | 1     | Input and output ports are not initialized.                                                                                                    |

### Table 147. Port Error and Status CSR n (SPn\_ERR\_STAT) Field Descriptions (continued)

### 5.73 Port Control CSR n (SPn\_CTL)

Each of the four ports is supported by a register of this type (see Table 148). The port control CSR n (SPn\_CTL) is shown in Figure 136 and described in Table 149. To change from 1 lane to 4 lanes there are 2 registers that need to be programmed. The SP\_IP\_MODE (offset 0x12004) bits 31-30 are set to be 1x/4p or 4 ports (1x mode each). The PER\_SET\_CNTL (offset 0x0020) bit 8 is set up for port (1x/4p) or priority based (1x mode each).

| Table 148. SPh_CTL Registers and the Associated Ports |                |                 |  |  |
|-------------------------------------------------------|----------------|-----------------|--|--|
| Register                                              | Address Offset | Associated Port |  |  |
| SP0_CTL                                               | 115Ch          | Port 0          |  |  |
| SP1_CTL                                               | 117Ch          | Port 1          |  |  |
| SP2_CTL                                               | 119Ch          | Port 2          |  |  |
| SP3_CTL                                               | 11BCh          | Port 3          |  |  |

### Table 148. SPn\_CTL Registers and the Associated Ports

#### Figure 136. Port Control CSR *n* (SP*n*\_CTL)

| 31               | 30 29                      |                           |                             |                                           | 26                         |                  | 24        |
|------------------|----------------------------|---------------------------|-----------------------------|-------------------------------------------|----------------------------|------------------|-----------|
| PORT_            | WIDTH                      | INITIA                    | ALIZED_PORT_W               | /IDTH                                     | POR                        | T_WIDTH_OVER     | RIDE      |
| R                | ·01                        |                           | R-000                       |                                           |                            | R/W-000          |           |
| 23               | 22                         | 21                        | 20                          | 19                                        | 18                         |                  | 16        |
| PORT_<br>DISABLE | OUTPUT_<br>PORT_<br>ENABLE | INPUT_<br>PORT_<br>ENABLE | ERROR_<br>CHECK_<br>DISABLE | MULTICAST_<br>PARTICIPANT                 |                            | Reserved         |           |
| R/W-0            | R/W-0                      | R/W-0                     | R/W-0                       | R-0                                       |                            | R-0              |           |
| 15               |                            |                           |                             |                                           |                            |                  | 8         |
|                  |                            |                           | Rese                        | erved                                     |                            |                  |           |
|                  |                            |                           | R                           | -0                                        |                            |                  |           |
| 7                |                            |                           | 4                           | 3                                         | 2                          | 1                | 0         |
|                  | Reserved                   |                           |                             |                                           | DROP_<br>PACKET_<br>ENABLE | PORT_<br>LOCKOUT | PORT_TYPE |
|                  | R                          | -0                        |                             | R/W-0                                     | R/W-0                      | R/W-0            | R-1       |
|                  | R                          |                           |                             | STOP_PORT_<br>FLD_ENC_<br>ENABLE<br>R/W-0 | PACKET_<br>ENABLE          | LOCKOUT          | _         |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 149. Port Control CSR n (SPn\_CTL) Field Descriptions

| Bit   | Field                  | Value     | Description                                                                                         |
|-------|------------------------|-----------|-----------------------------------------------------------------------------------------------------|
| 31–30 | PORT_WIDTH             |           | Port width. This read-only field indicates the hardware width of the port.                          |
|       |                        | 00b       | Single-lane port (valid for all ports)                                                              |
|       |                        | 01b       | Four-lane port (valid for port 0 only)                                                              |
|       |                        | 1xb       | Reserved                                                                                            |
| 29–27 | INITIALIZED_PORT_WIDTH |           | Initialized port width. This read-only field indicates the width of the ports after initialization. |
|       |                        | 000b      | Single-lane port, lane 0                                                                            |
|       |                        | 001b      | Single-lane port, lane 2 (See RapidIO Serial Spec 1.2, Chapter 4.4.10)                              |
|       |                        | 010b      | Four-lane port                                                                                      |
|       |                        | 011b–111b | Reserved                                                                                            |

### Table 149. Port Control CSR n (SPn\_CTL) Field Descriptions (continued)

| Bit   | Field                    | Value     | Description                                                                                                                                                                                                                                                                                                                                                |
|-------|--------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26–24 | PORT_WIDTH_OVERRIDE      |           | Port width override. This read-only field is available as a software means to override the hardware width.                                                                                                                                                                                                                                                 |
|       |                          | 000b      | No override                                                                                                                                                                                                                                                                                                                                                |
|       |                          | 001b      | Reserved                                                                                                                                                                                                                                                                                                                                                   |
|       |                          | 010b      | Force single lane, lane 0                                                                                                                                                                                                                                                                                                                                  |
|       |                          | 011b      | Force single lane, lane 2                                                                                                                                                                                                                                                                                                                                  |
|       |                          | 100b–111b | Reserved                                                                                                                                                                                                                                                                                                                                                   |
| 23    | PORT_DISABLE             |           | Port disable                                                                                                                                                                                                                                                                                                                                               |
|       |                          | 0         | Port receivers/drivers are enabled.                                                                                                                                                                                                                                                                                                                        |
|       |                          | 1         | Port receivers/drivers are disabled and are unable to receive/transmit any packets or control symbols.                                                                                                                                                                                                                                                     |
| 22    | OUTPUT_PORT_ENABLE       |           | Output port enable                                                                                                                                                                                                                                                                                                                                         |
|       |                          | 0         | The port is stopped and not enabled to issue any packets except<br>to route or respond to I/O logical maintenance packets,<br>depending upon the functionality of the processing element.<br>Control symbols are not affected and are sent normally.                                                                                                       |
|       |                          | 1         | The port is enabled to issue any packets.                                                                                                                                                                                                                                                                                                                  |
| 21    | INPUT_PORT_ENABLE        |           | Input port receive enable                                                                                                                                                                                                                                                                                                                                  |
|       |                          | 0         | The port is stopped and only enabled to route or respond I/O logical maintenance packets, depending upon the functionality of the processing element. Other packets generate packet-not-accepted control symbols to force an error condition to be signaled by the sending device. Control symbols are not affected and are received and handled normally. |
|       |                          | 1         | Port is enabled to respond to any packet.                                                                                                                                                                                                                                                                                                                  |
| 20    | ERROR_CHECK_DISABLE      |           | Error check disable                                                                                                                                                                                                                                                                                                                                        |
|       |                          | 0         | RapidIO transmission error checking and recovery are enabled.                                                                                                                                                                                                                                                                                              |
|       |                          | 1         | RapilO transmission error checking and recovery are disabled. If<br>an error condition occurs, device behavior is undefined.                                                                                                                                                                                                                               |
| 19    | MULTICAST_PARTICIPANT    | 0         | Multicast-event participant enable. This read-only bit is 0 to indicate that multicast-event control symbols cannot be accepted by this port.                                                                                                                                                                                                              |
| 18–4  | Reserved                 | 0         | These read-only bits return 0s when read.                                                                                                                                                                                                                                                                                                                  |
| 3     | STOP_PORT_FLD_ENC_ENABLE |           | Stop-on-fail enable                                                                                                                                                                                                                                                                                                                                        |
|       |                          | 0         | Even when the Output Failed-encountered bit is set, the port continues to attempt to transmit packets to the connected device.                                                                                                                                                                                                                             |
|       |                          | 1         | When the Output Failed-encountered bit is set, the port sets the Port Error bit in the Port <i>n</i> Error and Status CSR and stops attempting to send packets to the connected device. Packets are discarded if the Drop Packet Enable bit is set.                                                                                                        |
| 2     | DROP_PACKET_ENABLE       |           | Drop packet enable                                                                                                                                                                                                                                                                                                                                         |
|       |                          | 0         | The output port continues to try to transmit packets that have been rejected due to transmission errors.                                                                                                                                                                                                                                                   |
|       |                          | 1         | The output port drops packets that are acknowledged with a packet-not-accepted control symbol when the error failed threshold is exceeded. If the port "heals", and the current error rate falls below the failed threshold, the output no longer drops packets. (switch devices only)                                                                     |
| 1     | PORT_LOCKOUT             |           | Port lockout                                                                                                                                                                                                                                                                                                                                               |
|       |                          | 0         | The port is enabled to issue any packets.                                                                                                                                                                                                                                                                                                                  |
|       |                          | 1         | The port is stopped and is not enabled to issue or receive any packets. The input port can still follow the training procedure and can still send and respond to link-requests. All received packets return packet-not-accepted control symbols to force an error condition to be signaled by the sending device.                                          |



### Table 149. Port Control CSR *n* (SP*n*\_CTL) Field Descriptions (continued)

| Bit | Field     | Value | Description                                                                                         |
|-----|-----------|-------|-----------------------------------------------------------------------------------------------------|
| 0   | PORT_TYPE | 1     | Port type. This read-only bit indicates that the port is a serial port rather than a parallel port. |

### 5.74 Error Reporting Block Header Register (ERR\_RPT\_BH)

The Error Reporting Block Header Register (ERR\_RPT\_BH) is shown in Figure 137 and described in Table 150.

### Figure 137. Error Reporting Block Header Register (ERR\_RPT\_BH) - Address Offset 2000h

| 31 16   | 15 0    |
|---------|---------|
| EF_PTR  | EF_ID   |
| R-0000h | R-0007h |

LEGEND: R = Read only; -n = Value after reset

#### Table 150. Error Reporting Block Header Register (ERR\_RPT\_BH) Field Descriptions

| Bit   | Field  | Value | Description                                                             |
|-------|--------|-------|-------------------------------------------------------------------------|
| 31–16 | EF_PTR | 0000h | Hard-wired pointer to the next block in the data structure. NONE EXISTS |
| 15–0  | EF_ID  | 0007h | Hard-wired Extended Features ID                                         |



### 5.75 Logical/Transport Layer Error Detect CSR (ERR\_DET)

This register allows for the detection of logical/transport layer errors. The detectable errors are captured in the fields shown in Figure 138 and described in Table 151. For additional programming information, see Section 3.

### Figure 138. Logical/Transport Layer Error Detect CSR (ERR\_DET) - Address Offset 2008h

| 31                   | 30                   | 29    | )   | 28                 | 27                   | 26       | 25                  | 24                    |
|----------------------|----------------------|-------|-----|--------------------|----------------------|----------|---------------------|-----------------------|
| IO_ERR_<br>RSPNS     | MSG_ERR_<br>RSPNS    | Reser | ved | ERR_MSG_<br>FORMAT | ILL_TRANS_<br>DECODE | Reserved | MSG_REQ_<br>TIMEOUT | PKT_RSPNS_<br>TIMEOUT |
| R/W-0                | R/W-0                | R-    | 0   | R/W-0              | R/W-0                | R-0      | R/W-0               | R/W-0                 |
| 23                   | 22                   |       | 21  |                    |                      |          |                     |                       |
| UNSOLICITED<br>RSPNS | UNSUPPO              |       |     |                    |                      | Reserved |                     |                       |
| R/W-0                | R/W-                 | C     |     |                    |                      | R-0      |                     |                       |
|                      |                      |       |     |                    |                      |          |                     | 8                     |
|                      |                      |       |     | Rese               | erved                |          |                     |                       |
|                      |                      |       |     | R                  | -0                   |          |                     |                       |
| 7                    | 6                    | 5     |     |                    |                      |          |                     | 0                     |
| RX_CPPI_<br>SECURITY | RX_IO_DMA_<br>ACCESS |       |     |                    | Rese                 | erved    |                     |                       |
| R/W-0                | R/W-0                |       | R-0 |                    |                      |          |                     |                       |
|                      |                      |       |     |                    |                      |          |                     |                       |

LEGEND: R = Read; W = Write; -n = Value after reset

#### Table 151. Logical/Transport Layer Error Detect CSR (ERR\_DET) Field Descriptions

| Bit | Field            | Value | Description                                                                                                                 |
|-----|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------|
| 31  | IO_ERR_RSPNS     |       | I/O error response (endpoint device only)                                                                                   |
|     |                  | 0     | An LSU did not receive an ERROR response to an I/O logical layer request.                                                   |
|     |                  | 1     | An LSU received an ERROR response to an I/O logical layer request. To clear this bit, write 0 to it.                        |
| 30  | MSG_ERR_RSPNS    |       | Message error response (endpoint device only)                                                                               |
|     |                  | 0     | The TXU did not receive an ERROR response to a message logical layer request.                                               |
|     |                  | 1     | The TXU received an ERROR response to a message logical layer request. To clear this bit, write 0 to it.                    |
| 29  | Reserved         | 0     | This read-only bit returns 0 when read.                                                                                     |
| 28  | ERR_MSG_FORMAT   |       | Error in message format (endpoint device only)                                                                              |
|     |                  | 0     | The RXU did not receive a message data payload with an invalid size or segment.                                             |
|     |                  | 1     | The RXU received a message data payload with an invalid size or segment. To clear this bit, write 0 to it.                  |
| 27  | ILL_TRANS_DECODE |       | Illegal transaction decode (switch or endpoint device)                                                                      |
|     |                  |       | For an LSU or the TXU:                                                                                                      |
|     |                  | 0     | The LSU/TXU did not receive illegal fields in the response packet for an IO/message transaction.                            |
|     |                  | 1     | The LSU/TXU received illegal fields in the response packet for an IO/message transaction. To clear this bit, write 0 to it. |
|     |                  |       | For the MAU or the RXU:                                                                                                     |
|     |                  | 0     | The MAU/RXU did not receive illegal fields in the request packet for an IO/message transaction.                             |
|     |                  | 1     | The MAU/RXU received illegal fields in the request packet for an IO/message transaction. To clear this bit, write 0 to it.  |
| 26  | Reserved         | 0     | This read-only bit returns 0 when read.                                                                                     |

| Bit  | Field             | Value | Description                                                                                                                                                                         |
|------|-------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25   | MSG_REQ_TIMEOUT   |       | Message request timeout (endpoint device only)                                                                                                                                      |
|      |                   | 0     | A timeout has not been detected by RXU.                                                                                                                                             |
|      |                   | 1     | A timeout has been detected by the RXU. A required message request has not been received by the RXU within the specified time-out interval. To clear this bit, write 0 to it.       |
| 24   | PKT_RSPNS_TIMEOUT |       | Packet response timeout (endpoint device only)                                                                                                                                      |
|      |                   | 0     | A timeout has not been detected by an LSU or the TXU.                                                                                                                               |
|      |                   | 1     | A timeout has been detected by an LSU or the TXU. A required response has not been received by the LSU/TXU within the specified timeout interval. To clear this bit, write 0 to it. |
| 23   | UNSOLICITED_RSPNS |       | Unsolicited response (switch or endpoint device)                                                                                                                                    |
|      |                   | 0     | An unsolicited response packet has not been received by an LSU or the TXU.                                                                                                          |
|      |                   | 1     | An unsolicited response packet has been received by an LSU or the TXU. To clear this bit, write 0 to it.                                                                            |
| 22   | UNSUPPORTED_TRANS |       | Unsupported transaction (switch or endpoint device)                                                                                                                                 |
|      |                   | 0     | The MAU has not received an unsupported transaction.                                                                                                                                |
|      |                   | 1     | The MAU has received an unsupported transaction. That is, the MAU received a transaction that is not supported in the destination operations CAR. To clear this bit, write 0 to it. |
| 21–8 | Reserved          | 0     | These read-only bits return 0 when read.                                                                                                                                            |
| 7    | RX_CPPI_SECURITY  |       | RX CPPI security error                                                                                                                                                              |
|      |                   | 0     | The RXU has not detected an access block.                                                                                                                                           |
|      |                   | 1     | The RXU has detected an access block. That is, access to one of the RX queues was blocked. To clear this bit, write 0 to it.                                                        |
| 6    | RX_IO_DMA_ACCESS  |       | RX I/O DMA access error                                                                                                                                                             |
|      |                   | 0     | A DMA access to the MAU has not been blocked.                                                                                                                                       |
|      |                   | 1     | A DMA access to the MAU was blocked. To clear this bit, write 0 to it.                                                                                                              |
| 5–0  | Reserved          | 0     | These read-only bits return 0 when read.                                                                                                                                            |

### Table 151. Logical/Transport Layer Error Detect CSR (ERR\_DET) Field Descriptions (continued)



### 5.76 Logical/Transport Layer Error Enable CSR (ERR\_EN)

The logical/transport layer error enable CSR (ERR\_EN) is shown in Figure 139 and described in Table 152.

#### Figure 139. Logical/Transport Layer Error Enable CSR (ERR\_EN) - Address Offset 200Ch

| 31                              | 30                          | 29              |          | 28                            | 27                              | 26                    | 25                             | 24                              |
|---------------------------------|-----------------------------|-----------------|----------|-------------------------------|---------------------------------|-----------------------|--------------------------------|---------------------------------|
| IO_ERR_<br>RESP_<br>ENABLE      | MSG_ERR_<br>RESP_<br>ENABLE | Reser<br>(write |          | ERR_MSG_<br>FORMAT_<br>ENABLE | ILL_TRANS_<br>DECODE_<br>ENABLE | Reserved<br>(write 0) | MSG_REQ_<br>TIMEOUT_<br>ENABLE | PKT_RESP_<br>TIMEOUT_<br>ENABLE |
| R/W-0                           | R/W-0                       | R/W             | -0       | R/W-0                         | R/W-0                           | R/W-0                 | R/W-0                          | R/W-0                           |
| 23                              | 22                          |                 | 21       |                               |                                 |                       |                                |                                 |
| UNSOLICITED_<br>RESP_ENABLE     |                             |                 |          |                               |                                 | Reserved              |                                |                                 |
| R/W-0                           | R/W-0                       |                 |          |                               |                                 | R-0                   |                                |                                 |
|                                 |                             |                 |          |                               |                                 |                       |                                | 8                               |
|                                 |                             |                 |          | Re                            | eserved                         |                       |                                |                                 |
|                                 |                             |                 |          |                               | R-0                             |                       |                                |                                 |
| 7                               | 6                           | 5               |          |                               |                                 |                       |                                | 0                               |
| RX_CPPI_<br>SECURITY_<br>ENABLE | RX_IO_<br>SECURIT<br>ENABL  | Υ_              | Reserved |                               |                                 |                       |                                |                                 |
| R/W-0                           | R/W-0                       |                 | R-0      |                               |                                 |                       |                                |                                 |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

#### Table 152. Logical/Transport Layer Error Enable CSR (ERR\_EN) Field Descriptions

| Bit | Field                   | Value | Description                                                                                                                                                                                                                                    |
|-----|-------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | IO_ERR_RESP_ENABLE      |       | IO error response reporting enable                                                                                                                                                                                                             |
|     |                         | 0     | Disable reporting of an IO error response.                                                                                                                                                                                                     |
|     |                         | 1     | Enable reporting of an IO error response (endpoint device only).<br>Save and lock original request transaction capture information in all<br>Logical/Transport Layer Capture CSRs.                                                             |
| 30  | MSG_ERR_RESP_ENABLE     |       | Message error response reporting enable                                                                                                                                                                                                        |
|     |                         | 0     | Disable reporting of a message error response.                                                                                                                                                                                                 |
|     |                         | 1     | Enable reporting of a message error response (endpoint device only). Save and lock transaction capture information in all Logical/Transport Layer Capture CSRs.                                                                                |
| 29  | Reserved                | 0     | Always write 0 to this reserved bit.                                                                                                                                                                                                           |
| 28  | ERR_MSG_FORMAT_ENABLE   |       | Message format error reporting enable                                                                                                                                                                                                          |
|     |                         | 0     | Disable reporting of a message format error.                                                                                                                                                                                                   |
|     |                         | 1     | Enable reporting of a message format error (endpoint device only).<br>Save and lock transaction capture information in Logical/Transport<br>Layer Device ID and Control Capture CSRs.                                                          |
| 27  | ILL_TRANS_DECODE_ENABLE |       | Illegal transaction decode error reporting enable                                                                                                                                                                                              |
|     |                         | 0     | Disable reporting of an illegal transaction decode error.                                                                                                                                                                                      |
|     |                         | 1     | Enable reporting of an illegal transaction decode error (switch or endpoint device). Save and lock transaction capture information in Logical/Transport Layer Device ID and Control Capture CSRs.                                              |
| 26  | Reserved                | 0     | Always write 0 to this reserved bit.                                                                                                                                                                                                           |
| 25  | MSG_REQ_TIMEOUT_ENABLE  |       | Message request time-out error reporting enable                                                                                                                                                                                                |
|     |                         | 0     | Disable reporting of a message request time-out error.                                                                                                                                                                                         |
|     |                         | 1     | Enable reporting of a message request time-out error (endpoint device only). Save and lock transaction capture information in Logical/Transport Layer Device ID and Control Capture CSRs for the last message-segment request packet received. |

### Table 152. Logical/Transport Layer Error Enable CSR (ERR\_EN) Field Descriptions (continued)

| Bit  | Field                    | Value | Description                                                                                                                                                                                                                                                          |
|------|--------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24   | PKT_RESP_TIMEOUT_ENABLE  |       | Packet response time-out error reporting enable                                                                                                                                                                                                                      |
|      |                          | 0     | Disable reporting of a packet response time-out error.                                                                                                                                                                                                               |
|      |                          | 1     | Enable reporting of a packet response time-out error (endpoint device only). Save and lock original request address in Logical/Transport Layer Address Capture CSRs. Save and lock original request Destination ID in Logical/Transport Layer Device ID Capture CSR. |
| 23   | UNSOLICITED_RESP_ENABLE  |       | Unsolicited response error reporting enable                                                                                                                                                                                                                          |
|      |                          | 0     | Disable reporting of an unsolicited response error.                                                                                                                                                                                                                  |
|      |                          | 1     | Enable reporting of an unsolicited response error (switch or endpoint device). Save and lock transaction capture information in Logical/Transport Layer Device ID and Control Capture CSRs.                                                                          |
| 22   | UNSUPPORTED_TRANS_ENABLE |       | Unsupported transaction error reporting enable                                                                                                                                                                                                                       |
|      |                          | 0     | Disable reporting of an unsupported transaction error.                                                                                                                                                                                                               |
|      |                          | 1     | Enable reporting of an unsupported transaction error (switch or endpoint device). Save and lock transaction capture information in Logical/Transport Layer Device ID and Control Capture CSRs.                                                                       |
| 21–8 | Reserved                 | 0     | These read-only bits return 0s when read.                                                                                                                                                                                                                            |
| 7    | RX_CPPI_SECURITY_ENABLE  |       | RX CPPI security error reporting enable                                                                                                                                                                                                                              |
|      |                          | 0     | Disable reporting of an attempt at unauthorized access to a RX queue.                                                                                                                                                                                                |
|      |                          | 1     | Enable reporting of attempt at unauthorized access to a RX queue.<br>Save and Lock capture information in appropriate Logical/Transport<br>Layer Capture CSRs.                                                                                                       |
| 6    | RX_IO_SECURITY_ENABLE    |       | RX I/O secuirty error reporting enable                                                                                                                                                                                                                               |
|      |                          | 0     | Disable reporting of attempt at unauthorized access to a memory location.                                                                                                                                                                                            |
|      |                          | 1     | Enable reporting of attempt at unauthorized access to a memory location. Save and Lock capture information in appropriate Logical/Transport Layer Capture CSRs.                                                                                                      |
| 5–0  | Reserved                 | 0     | These read-only bits return 0s when read.                                                                                                                                                                                                                            |



### 5.77 Logical/Transport Layer High Address Capture CSR (H\_ADDR\_CAPT)

The logical/transport layer high address capture CSR (H\_ADDR\_CAPT) is shown in Figure 140 and described in Table 153.

# Figure 140. Logical/Transport Layer High Address Capture CSR (H\_ADDR\_CAPT) - Address Offset 2010h

| 31 |               | 0 |
|----|---------------|---|
|    | ADDRESS_63_32 |   |
|    | R-0000000h    |   |

LEGEND: R = Read only; -n = Value after reset

#### Table 153. Logical/Transport Layer High Address Capture CSR (H\_ADDR\_CAPT) Field Descriptions

|   | Bit  | Field         | Value                        | Description                                                                                                                       |
|---|------|---------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Ī | 31–0 | ADDRESS_63_32 | 00000000h<br>to<br>FFFFFFFFh | Most significant 32 bits of the address associated with the error (only valid for devices supporting 66-bit and 50-bit addresses) |

### 5.78 Logical/Transport Layer Address Capture CSR (ADDR\_CAPT)

The logical/transport layer address capture CSR (ADDR\_CAPT) is shown in Figure 141 and described in Table 154.

### Figure 141. Logical/Transport Layer Address Capture CSR (ADDR\_CAPT) - Address Offset 2014h

| 31 |              |           |          |   |        | 16 |
|----|--------------|-----------|----------|---|--------|----|
|    | ADD          | RESS_31_3 |          |   |        |    |
|    |              | R-0000h   |          |   |        |    |
| 15 |              | 3         | 2        | 1 |        | 0  |
|    | ADDRESS_31_3 |           | Reserved |   | XAMSBS |    |
|    | R-0000h      |           | R-0      |   | R-00   |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 154. Logical/Transport Layer Address Capture CSR (ADDR\_CAPT) Field Descriptions

| Bit  | Field        | Value                        | Description                                                        |
|------|--------------|------------------------------|--------------------------------------------------------------------|
| 31–3 | ADDRESS_31_3 | 00000000h<br>to<br>1FFFFFFFh | Least significant 29 bits of the address associated with the error |
| 2    | Reserved     | 0                            | This read-only bit returns 0 when read.                            |
| 1–0  | XAMSBS       | 00b–11b                      | Extended address bits of the address associated with the error     |



### 5.79 Logical/Transport Layer Device ID Capture CSR (ID\_CAPT)

The logical/transport layer device ID capture CSR (ID\_CAPT) is shown in Figure 142 and described in Table 155.

#### Figure 142. Logical/Transport Layer Device ID Capture CSR (ID\_CAPT) - Address Offset 2018h

| DEOTID   |
|----------|
| DESTID   |
| R-00h    |
| 0        |
| SOURCEID |
| R-00h    |
|          |

LEGEND: R = Read only; -n = Value after reset

#### Table 155. Logical/Transport Layer Device ID Capture CSR (ID\_CAPT) Field Descriptions

| Bit   | Field        | Value   | Description                                                                                         |
|-------|--------------|---------|-----------------------------------------------------------------------------------------------------|
| 31–24 | MSB_DESTID   | 00h–FFh | Most significant byte of the destinationID associated with the error (large transport systems only) |
| 23–16 | DESTID       | 00h–FFh | The destinationID associated with the error                                                         |
| 15–8  | MSB_SOURCEID | 00h–FFh | Most significant byte of the source ID associated with the error (large transport systems only)     |
| 7–0   | SOURCEID     | 00h–FFh | The sourceID associated with the error                                                              |

# 5.80 Logical/Transport Layer Control Capture CSR (CTRL\_CAPT)

The logical/transport layer control capture CSR (CTRL\_CAPT) is shown in Figure 143 and described in Table 156.

# Figure 143. Logical/Transport Layer Control Capture CSR (CTRL\_CAPT) - Address Offset 201Ch

| 31 | 28      | 3 27 24 | 23      | 16 |
|----|---------|---------|---------|----|
|    | FTYPE   | TTYPE   | MSGINFO |    |
|    | R-0h    | R-0h    | R-00h   |    |
| 15 |         |         |         | 0  |
|    |         | IMP_SI  | PECIFIC |    |
|    | R-0000h |         |         |    |

LEGEND: R = Read only; -n = Value after reset

### Table 156. Logical/Transport Layer Control Capture CSR (CTRL\_CAPT) Field Descriptions

| Bit   | Field        | Value       | Description                                                                                                                        |  |
|-------|--------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|--|
| 31–28 | FTYPE        | 0h–Fh       | Format type associated with the error                                                                                              |  |
| 27–24 | TTYPE        | 0h–Fh       | Transaction type associated with the error                                                                                         |  |
| 23–16 | MSGINFO      | 00h–FFh     | Letter, mailbox, and message segment for the last message request received for the mailbox that had an error (message errors only) |  |
| 15–0  | IMP_SPECIFIC | 0000h-FFFFh | Implementation specific information associated with the error                                                                      |  |



SRIO Registers

# 5.81 Port-Write Target Device ID CSR (PW\_TGT\_ID)

The port-write target device ID CSR (PW\_TGT\_ID) is shown in Figure 144 and described in Table 157. For additional programming information, see Section 2.3.5.

### Figure 144. Port-Write Target Device ID CSR (PW\_TGT\_ID) - Address Offset 2028h

| 31 |              | 24 23    |          | 16 |
|----|--------------|----------|----------|----|
|    | DEVICEID_MSB |          | DEVICEID |    |
|    | R/W-00h      |          | R/W-00h  |    |
| 15 |              |          |          | 0  |
|    |              | Reserved |          |    |
|    |              | R-0000h  |          |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 157. Port-Write Target Device ID CSR (PW\_TGT\_ID) Field Descriptions

| Bit   | Field        | Value   | Description                                                                             |
|-------|--------------|---------|-----------------------------------------------------------------------------------------|
| 31–24 | DEVICEID_MSB | 00h–FFh | Most significant byte of the port-write target device ID (large transport systems only) |
| 23–16 | DEVICEID     | 00h–FFh | Port-write target deviceID                                                              |
| 15–0  | Reserved     | 0000h   | These read-only bits return 0s when read.                                               |

# 5.82 Port Error Detect CSR n (SPn\_ERR\_DET)

Each of the four ports is supported by a register of this type (see Table 158). The port error detect CSR n (SPn ERR DET) is shown in Figure 145 and described in Table 159.

| Table 158. SPn_ERR | _DET Registers and the Associated Ports |
|--------------------|-----------------------------------------|
|--------------------|-----------------------------------------|

| Register    | Address Offset | Associated Port |  |
|-------------|----------------|-----------------|--|
| SP0_ERR_DET | 2040h          | Port 0          |  |
| SP1_ERR_DET | 2080h          | Port 1          |  |
| SP2_ERR_DET | 20C0h          | Port 2          |  |
| SP3_ERR_DET | 2100h          | Port 3          |  |

### Figure 145. Port Error Detect CSR n (SPn\_ERR\_DET)



LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 159. Port Error Detect CSR n (SPn\_ERR\_DET) Field Descriptions

| Bit   | Field                     | Value | Description                                                                                                                                                                                  |
|-------|---------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | ERR_IMP_SPECIFIC          |       | Implementation-specific error. This bit covers errors that are a result of<br>an illegal field in a maintenance packet, an illegal destination ID, and<br>an unsupported transaction.        |
|       |                           | 0     | An implementation specific error has not been detected.                                                                                                                                      |
|       |                           | 1     | An implementation specific error has been detected.                                                                                                                                          |
| 30–23 | Reserved                  | 0     | These read-only bits return 0s when read.                                                                                                                                                    |
| 22    | CORRUPT_CNTL_SYM          |       | Bad CRC in control symbol                                                                                                                                                                    |
|       |                           | 0     | The port did not receive a control symbol with a bad CRC value.                                                                                                                              |
|       |                           | 1     | The port received a control symbol with a bad CRC value.                                                                                                                                     |
| 21    | CNTL_SYM_UNEXPECTED_ACKID |       | Unexpected ackID in control symbol                                                                                                                                                           |
|       |                           | 0     | The port did not receive an acknowledge control symbol with an unexpected ackID (packet-accepted or packet-retry).                                                                           |
|       |                           | 1     | The port received an acknowledge control symbol with an unexpected ackID (packet-accepted or packet-retry). The capture registers do not have valid information during this error detection. |



# Table 159. Port Error Detect CSR n (SPn\_ERR\_DET) Field Descriptions (continued)

| Bit  | Field                    | Value | Description                                                                                                                                                                                                                           |
|------|--------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20   | RCVD_PKT_NOT_ACCPT       |       | Packet-not-accepted control symbol                                                                                                                                                                                                    |
|      |                          | 0     | The port did not receive a packet-not-accepted acknowledge control symbol.                                                                                                                                                            |
|      |                          | 1     | The port received a packet-not-accepted acknowledge control symbol.                                                                                                                                                                   |
| 19   | PKT_UNEXPECTED_ACKID     |       | Unexpected ackID in packet                                                                                                                                                                                                            |
|      |                          | 0     | The port did not receive a packet with unexpected/out-of-sequence ackID.                                                                                                                                                              |
|      |                          | 1     | The port received a packet with unexpected/out-of-sequence ackID.                                                                                                                                                                     |
| 18   | RCVD_PKT_WITH_BAD_CRC    |       | Bad CRC in packet                                                                                                                                                                                                                     |
|      |                          | 0     | The port did not receive a packet with a bad CRC value.                                                                                                                                                                               |
|      |                          | 1     | The port received a packet with a bad CRC value.                                                                                                                                                                                      |
| 17   | RCVD_PKT_OVER_276B       |       | Oversize packet                                                                                                                                                                                                                       |
|      |                          | 0     | The port did not receive packet that exceeds the maximum allowed size.                                                                                                                                                                |
|      |                          | 1     | The port received packet that exceeds the maximum allowed size.                                                                                                                                                                       |
| 16–6 | Reserved                 | 0     | These read-only bits return 0s when read.                                                                                                                                                                                             |
| 5    | NON_OUTSTANDING_ACKID    |       | Non-outstanding ackID                                                                                                                                                                                                                 |
|      |                          | 0     | The port did not receive a link response with a non-outstanding ackID.                                                                                                                                                                |
|      |                          | 1     | The port received a link response with an ackID that is not outstanding.<br>The capture registers do not have valid information during this error<br>detection.                                                                       |
| 4    | PROTOCOL_ERROR           |       | Protocol error                                                                                                                                                                                                                        |
|      |                          | 0     | The port did not receive an unexpected packet or control symbol.                                                                                                                                                                      |
|      |                          | 1     | The port received an unexpected packet or control symbol.                                                                                                                                                                             |
| 3    | Reserved                 | 0     | This read-only bit returns 0 when read.                                                                                                                                                                                               |
| 2    | DELINEATION_ERROR        |       | Delineation error                                                                                                                                                                                                                     |
|      |                          | 0     | The port did not detect a delineation error.                                                                                                                                                                                          |
|      |                          | 1     | The port detected a delineation error. The port received an unaligned /SC/ or /PD/ or undefined code-group. The capture registers do not have valid information during this error detection.                                          |
| 1    | UNSOLICITED_ACK_CNTL_SYM |       | Unsolicited acknowledge control symbol                                                                                                                                                                                                |
|      |                          | 0     | The port did not receive an unexpected acknowledge control symbol.                                                                                                                                                                    |
|      |                          | 1     | The port received an unexpected acknowledge control symbol.                                                                                                                                                                           |
| 0    | LINK_TIMEOUT             |       | Link timeout                                                                                                                                                                                                                          |
|      |                          | 0     | The port did not experience a link timeout.                                                                                                                                                                                           |
|      |                          | 1     | The port experienced a link timeout. The port did not receive an acknowledge or link-response control symbol within the specified time-out interval. The capture registers do not have valid information during this error detection. |

### 5.83 Port Error Rate Enable CSR n (SPn\_RATE\_EN)

Each of the four ports is supported by a register of this type (see Table 160). The port error rate enable CSR n (SPn RATE EN) is shown in Figure 146 and described in Table 161.

| Table 160. SP <i>n</i> _RATE_B | EN Registers and the Associated Ports |
|--------------------------------|---------------------------------------|
|--------------------------------|---------------------------------------|

| Register    | Address Offset | Associated Port |  |
|-------------|----------------|-----------------|--|
| SP0_RATE_EN | 2044h          | Port 0          |  |
| SP1_RATE_EN | 2084h          | Port 1          |  |
| SP2_RATE_EN | 20C4h          | Port 2          |  |
| SP3_RATE_EN | 2104h          | Port 3          |  |

### Figure 146. Port Error Rate Enable CSR n (SPn\_RATE\_EN)



LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 161. Port Error Rate Enable CSR n (SPn\_RATE\_EN) Field Descriptions

| Bit   | Field                        | Value | Description                                                                            |
|-------|------------------------------|-------|----------------------------------------------------------------------------------------|
| 31    | EN_IMP_SPECIFIC              |       | Rate counting enable for implementation-specific errors                                |
|       |                              | 0     | Disable error rate counting of implementation specific errors                          |
|       |                              | 1     | Enable error rate counting of implementation specific errors.                          |
| 30–23 | Reserved                     | 0     | These read-only bits return 0s when read.                                              |
| 22    | CORRUPT_CNTL_SYM_ENABLE      |       | Rate counting enable for corrupt control symbols                                       |
|       |                              | 0     | Disable error rate counting of a corrupt control symbol.                               |
|       |                              | 1     | Enable error rate counting of a corrupt control symbol.                                |
| 21    | CNTL_SYM_UNEXPECTED_ACKID_EN |       | Rate counting enable for control symbols with unexpected ackIDs                        |
|       |                              | 0     | Disable error rate counting of an acknowledge control symbol with an unexpected ackID. |
|       |                              | 1     | Enable error rate counting of an acknowledge control symbol with an unexpected ackID.  |
| 20    | RCVED_PKT_NOT_ACCPT_EN       |       | Rate counting enable for packet-not-accepted control symbols                           |
|       |                              | 0     | Disable error rate counting of received packet-not-accepted control symbols.           |
|       |                              | 1     | Enable error rate counting of received packet-not-accepted control symbols.            |



# Table 161. Port Error Rate Enable CSR *n* (SP*n*\_RATE\_EN) Field Descriptions (continued)

| Bit  | Field                       | Value | Description                                                                                   |
|------|-----------------------------|-------|-----------------------------------------------------------------------------------------------|
| 19   | PKT_UNEXPECTED_ACKID_EN     |       | Rate counting enable for packets with unexpected ackIDs                                       |
|      |                             | 0     | Disable error rate counting of packets with<br>unexpected/out-of-sequence ackIDs              |
|      |                             | 1     | Enable error rate counting of packets with<br>unexpected/out-of-sequence ackIDs.              |
| 18   | RCVED_PKT_WITH_BAD_CRC_EN   |       | Rate counting enable for packets with bad CRC                                                 |
|      |                             | 0     | Disable error rate counting of packets with a bad CRC values.                                 |
|      |                             | 1     | Enable error rate counting of packets with a bad CRC values.                                  |
| 17   | RCVED_PKT_OVER_276B_EN      |       | Rate counting enable for oversize packets                                                     |
|      |                             | 0     | Disable error rate counting of packets that exceed the maximum allowed size.                  |
|      |                             | 1     | Enable error rate counting of packets that exceed the maximum allowed size.                   |
| 16–6 | Reserved                    | 0     | These read-only bits return 0s when read.                                                     |
| 5    | NON_OUTSTANDING_ACKID_EN    |       | Rate counting enable for non-outstanding ackIDs                                               |
|      |                             | 0     | Disable error rate counting of link-responses received with an ackID that is not outstanding. |
|      |                             | 1     | Enable error rate counting of link-responses received with an ackID that is not outstanding.  |
| 4    | PROTOCOL_ERROR_EN           |       | Rate counting enable for protocol errors                                                      |
|      |                             | 0     | Disable error rate counting of protocol errors.                                               |
|      |                             | 1     | Enable error rate counting of protocol errors.                                                |
| 3    | Reserved                    | 0     | This read-only bit returns 0 when read.                                                       |
| 2    | DELINEATION_ERROR_EN        |       | Rate counting enable for delineation errors                                                   |
|      |                             | 0     | Disable error rate counting of delineation errors.                                            |
|      |                             | 1     | Enable error rate counting of delineation errors.                                             |
| 1    | UNSOLICITED_ACK_CNTL_SYM_EN |       | Rate counting enable for unsolicited acknowledge control symbols                              |
|      |                             | 0     | Disable error rate counting of unsolicited acknowledge control symbols.                       |
|      |                             | 1     | Enable error rate counting of unsolicited acknowledge control symbols.                        |
| 0    | LINK_TIMEOUT_EN             |       | Rate counting enable for link time-out errors                                                 |
|      |                             | 0     | Disable error rate counting of link timeout errors.                                           |
|      |                             | 1     | Enable error rate counting of link timeout errors.                                            |

# 5.84 Port n Attributes Error Capture CSR 0 (SPn\_ERR\_ATTR\_CAPT\_DBG0)

Each of the four ports is supported by a register of this type (see ). The port *n* attributes error capture CSR 0 (SP*n*\_ERR\_ATTR\_CAPT\_DBG0) is shown in Figure 147 and described in Table 163.

| Table 162. SPn_ERR_ATTR_CAPT_DBG0 Registers and the Assoc | iated Ports |
|-----------------------------------------------------------|-------------|
|-----------------------------------------------------------|-------------|

| Register               | Address Offset | Associated Port |  |
|------------------------|----------------|-----------------|--|
| SP0_ERR_ATTR_CAPT_DBG0 | 2048h          | Port 0          |  |
| SP1_ERR_ATTR_CAPT_DBG0 | 2088h          | Port 1          |  |
| SP2_ERR_ATTR_CAPT_DBG0 | 20C8h          | Port 2          |  |
| SP3_ERR_ATTR_CAPT_DBG0 | 2108h          | Port 3          |  |

### Figure 147. Port *n* Attributes Error Capture CSR 0 (SP*n*\_ERR\_ATTR\_CAPT\_DBG0)

| 31        | 30 | 29           | 28 |            | 24 | 23           |                        |
|-----------|----|--------------|----|------------|----|--------------|------------------------|
| INFO_TYPE |    | Reserved     |    | ERROR_TYPE |    | IMP_SPECIFIC |                        |
| R-00      |    | R-0          |    | R-00000    |    | R-00000h     |                        |
|           |    |              |    |            | 4  | 3 1          | 0                      |
|           |    | IMP_SPECIFIC |    |            |    | Reserved     | CAPTURE_<br>VALID_INFO |
|           |    | R-00000h     |    |            |    | R-00         | R/W-0                  |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

# Table 163. Port n Attributes Error Capture CSR 0 (SPn\_ERR\_ATTR\_CAPT\_DBG0) Field Descriptions

| Bit   | Field              | Value         | Description                                                                                                                                                                                                                                                         |
|-------|--------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30 | 31–30 INFO_TYPE    |               | Type of information logged                                                                                                                                                                                                                                          |
|       |                    | 00b           | Packet                                                                                                                                                                                                                                                              |
|       |                    | 01b           | Control symbol (only error capture register 0 is valid)                                                                                                                                                                                                             |
|       |                    | 10b           | Implementation specific (capture register contents are implementation specific)                                                                                                                                                                                     |
|       |                    | 11b           | Reserved                                                                                                                                                                                                                                                            |
| 29    | Reserved           | 0             | This read-only bit returns 0 when read.                                                                                                                                                                                                                             |
| 28–24 | ERROR_TYPE         | 00000b-11111b | Encoded value of captured error bit in the Port <i>n</i> Error Detect Register                                                                                                                                                                                      |
| 23–4  | IMP_SPECIFIC       | 00000h-FFFFFh | Implementation Dependent Error Information                                                                                                                                                                                                                          |
| 3–1   | Reserved           | 0             | These read-only bits return 0s when read.                                                                                                                                                                                                                           |
| 0     | CAPTURE_VALID_INFO |               | Valid information captured                                                                                                                                                                                                                                          |
|       |                    | 0             | The packet/control symbol capture registers do not contain valid information.                                                                                                                                                                                       |
|       |                    | 1             | The packet/control symbol capture registers contain valid<br>information. For control symbols, only capture register 0 contains<br>meaningful information. A software write of 0 clears this bit and<br>subsequently unlocks all the capture registers of the port. |



# 5.85 Port n Error Capture CSR 1 (SPn\_ERR\_CAPT\_DBG1)

Each of the four ports is supported by a register of this type (see Table 164). SP*n*\_ERR\_CAPT\_DBG1 is shown in Figure 148 and described in Table 165.

### Table 164. SPn\_ERR\_CAPT\_DBG1 Registers and the Associated Ports

| Register          | Address Offset | Associated Port |
|-------------------|----------------|-----------------|
| SP0_ERR_CAPT_DBG1 | 204Ch          | Port 0          |
| SP1_ERR_CAPT_DBG1 | 208Ch          | Port 1          |
| SP2_ERR_CAPT_DBG1 | 20CCh          | Port 2          |
| SP3_ERR_CAPT_DBG1 | 210Ch          | Port 3          |

### Figure 148. Port *n* Error Capture CSR 1 (SP*n*\_ERR\_CAPT\_DBG1)

| 31 | 0          |
|----|------------|
|    | CAPTURE0   |
|    | R-0000000h |

LEGEND: R = Read only; -n = Value after reset

### Table 165. Port *n* Error Capture CSR 1 (SP*n*\_ERR\_CAPT\_DBG1) Field Descriptions

| Bit  | Field    | Value                       | Description                                                                                                                                                                                                      |
|------|----------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–0 | CAPTURE0 | 00000000h<br>to<br>FFFFFFFh | In the case of a control-symbol error:<br>Control character and control symbol that correspond to the error<br>In the case of a packet error:<br>Bytes 0 to 3 of the packet header that corresponds to the error |

# 5.86 Port n Error Capture CSR 2 (SPn\_ERR\_CAPT\_DBG2)

Each of the four ports is supported by a register of this type (see Table 166). SP*n*\_ERR\_CAPT\_DBG2 is shown in Figure 149 and described in Table 167.

### Table 166. SPn\_ERR\_CAPT\_DBG2 Registers and the Associated Ports

| Register          | Address Offset | Associated Port |
|-------------------|----------------|-----------------|
| SP0_ERR_CAPT_DBG2 | 2050h          | Port 0          |
| SP1_ERR_CAPT_DBG2 | 2090h          | Port 1          |
| SP2_ERR_CAPT_DBG2 | 20D0h          | Port 2          |
| SP3_ERR_CAPT_DBG2 | 2110h          | Port 3          |

### Figure 149. Port *n* Error Capture CSR 2 (SP*n*\_ERR\_CAPT\_DBG2)

| 31 | 0          |
|----|------------|
|    | CAPTURE1   |
|    | R-0000000h |

LEGEND: R = Read only; -n = Value after reset

### Table 167. Port n Error Capture CSR 2 (SPn\_ERR\_CAPT\_DBG2) Field Descriptions

| Bit  | Field    | Value                        | Description                                                     |
|------|----------|------------------------------|-----------------------------------------------------------------|
| 31–0 | CAPTURE1 | 00000000h<br>to<br>FFFFFFFFh | Bytes 4 to 7 of the packet header that corresponds to the error |



# 5.87 Port n Error Capture CSR 3 (SPn\_ERR\_CAPT\_DBG3)

Each of the four ports is supported by a register of this type (see Table 168). SP*n*\_ERR\_CAPT\_DBG3 is shown in Figure 150 and described in Table 169.

### Table 168. SPn\_ERR\_CAPT\_DBG3 Registers and the Associated Ports

| Register          | Address Offset | Associated Port |  |
|-------------------|----------------|-----------------|--|
| SP0_ERR_CAPT_DBG3 | 2054h          | Port 0          |  |
| SP1_ERR_CAPT_DBG3 | 2094h          | Port 1          |  |
| SP2_ERR_CAPT_DBG3 | 20D4h          | Port 2          |  |
| SP3_ERR_CAPT_DBG3 | 2114h          | Port 3          |  |

### Figure 150. Port *n* Error Capture CSR 3 (SPn\_ERR\_CAPT\_DBG3)

| 31 | 0          |
|----|------------|
|    | CAPTURE2   |
|    | R-0000000h |

LEGEND: R = Read only; -n = Value after reset

### Table 169. Port n Error Capture CSR 3 (SPn\_ERR\_CAPT\_DBG3) Field Descriptions

| Bit  | Field    | Value                       | Description                                                      |
|------|----------|-----------------------------|------------------------------------------------------------------|
| 31–0 | CAPTURE2 | 00000000h<br>to<br>FFFFFFFh | Bytes 8 to 11 of the packet header that corresponds to the error |

# 5.88 Port n Error Capture CSR 4 (SPn\_ERR\_CAPT\_DBG4)

Each of the four ports is supported by a register of this type (see Table 170). The port *n* packet/control symbol error capture CSR 4 (SP*n*\_ERR\_CAPT\_DBG4) is shown in Figure 151 and described in Table 171.

### Table 170. SPn\_ERR\_CAPT\_DBG4 Registers and the Associated Ports

| Register          | Address Offset | Associated Port |  |
|-------------------|----------------|-----------------|--|
| SP0_ERR_CAPT_DBG4 | 2058h          | Port 0          |  |
| SP1_ERR_CAPT_DBG4 | 2098h          | Port 1          |  |
| SP2_ERR_CAPT_DBG4 | 20D8h          | Port 2          |  |
| SP3_ERR_CAPT_DBG4 | 2118h          | Port 3          |  |

### Figure 151. Port *n* Error Capture CSR 4 (SP*n*\_ERR\_CAPT\_DBG4)

| 31 0       |
|------------|
| CAPTURE3   |
| R-0000000h |

LEGEND: R = Read only; -n = Value after reset

### Table 171. Port *n* Error Capture CSR 4 (SP*n*\_ERR\_CAPT\_DBG4) Field Descriptions

| Bit  | Field    | Value                       | Description                                                       |
|------|----------|-----------------------------|-------------------------------------------------------------------|
| 31–0 | CAPTURE3 | 00000000h<br>to<br>FFFFFFFh | Bytes 12 to 15 of the packet header that corresponds to the error |



# 5.89 Port Error Rate CSR n (SPn\_ERR\_RATE)

Each of the four ports is supported by a register of this type (see Table 172).  $SPn_ERR_RATE$  is shown in Figure 152 and described in Table 173.

| Table 172. SPn_ERR_RATE Registers and the Associated Ports |                |                 |  |  |
|------------------------------------------------------------|----------------|-----------------|--|--|
| Register                                                   | Address Offset | Associated Port |  |  |
| SP0_ERR_RATE                                               | 2068h          | Port 0          |  |  |
| SP1_ERR_RATE                                               | 20A8h          | Port 1          |  |  |
| SP2_ERR_RATE                                               | 20E8h          | Port 2          |  |  |
| SP3_ERR_RATE                                               | 2128h          | Port 3          |  |  |

### Figure 152. Port Error Rate CSR n (SPn\_ERR\_RATE)

| 31              | 24 23 18          | 17 16                   |
|-----------------|-------------------|-------------------------|
| ERROR_RATE_BIAS | Reserved          | ERROR_RATE_<br>RECOVERY |
| R/W-FFh         | R-00h             | R/W-00                  |
| 15              | 8 7               | 0                       |
| PEAK_ERROR_RATE | ERROR_RATE_COUNTE | R                       |
| R/W-00h         | R/W-00h           |                         |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 173. Port Error Rate CSR n (SPn\_ERR\_RATE) Field Descriptions

| Bit   | Field               | Value                                                                          | Description                                                                                                                                                                                                 |
|-------|---------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–24 | ERROR_RATE_BIAS     |                                                                                | These bits provide the error rate bias value.                                                                                                                                                               |
|       |                     | 00h                                                                            | Do not decrement the error rate counter                                                                                                                                                                     |
|       |                     | 01h                                                                            | Decrement every 1ms (nominal)                                                                                                                                                                               |
|       |                     | 03h                                                                            | Decrement every 10ms (nominal)                                                                                                                                                                              |
|       |                     | 07h                                                                            | Decrement every 100ms                                                                                                                                                                                       |
|       |                     | 0Fh                                                                            | Decrement every 1s (nominal)                                                                                                                                                                                |
|       |                     | 1Fh                                                                            | Decrement every 10s (nominal)                                                                                                                                                                               |
|       |                     | 3Fh                                                                            | Decrement every 100s (nominal)                                                                                                                                                                              |
|       |                     | 7Fh                                                                            | Decrement every 1000s (nominal)                                                                                                                                                                             |
|       |                     | FFh                                                                            | Decrement every 10000s (nominal)                                                                                                                                                                            |
|       |                     | Other                                                                          | Reserved                                                                                                                                                                                                    |
| 23–18 | Reserved            | 00h                                                                            | These read-only bits return 0s when read.                                                                                                                                                                   |
| 17–16 | ERROR_RATE_RECOVERY |                                                                                | These bits limit the incrementing of the error rate counter above the failed threshold trigger.                                                                                                             |
|       |                     | 00b                                                                            | Only count 2 errors above                                                                                                                                                                                   |
|       |                     | 01b                                                                            | Only count 4 errors above                                                                                                                                                                                   |
|       |                     | 10b                                                                            | Only count 16 errors above                                                                                                                                                                                  |
|       |                     | 11b                                                                            | Do not limit incrementing the error rate count                                                                                                                                                              |
| 15–8  | PEAK_ERROR_RATE     | 00h–FFh This field contains the peak value attained by the error rate counter. |                                                                                                                                                                                                             |
| 7–0   | ERROR_RATE_COUNTER  | 00h–FFh                                                                        | These bits maintain a count of the number of transmission errors that have occurred. If this value equals the value contained in the error rate threshold trigger register, then an error will be reported. |

# 5.90 Port Error Rate Threshold CSR n (SPn\_ERR\_THRESH)

Each of the four ports is supported by a register of this type (see ). The port error rate threshold CSR n (SPn\_ERR\_THRESH) is shown in Figure 153 and described in Table 175.

### Table 174. SPn\_ERR\_THRESH Registers and the Associated Ports

| Register       | Address Offset | Associated Port |  |
|----------------|----------------|-----------------|--|
| SP0_ERR_THRESH | 206Ch          | Port 0          |  |
| SP1_ERR_THRESH | 20ACh          | Port 1          |  |
| SP2_ERR_THRESH | 20ECh          | Port 2          |  |
| SP3_ERR_THRESH | 212Ch          | Port 3          |  |

Figure 153. Port Error Rate Threshold CSR n (SPn ERR THRESH)

| 31 |                          | 24 23    |                            | 16 |
|----|--------------------------|----------|----------------------------|----|
|    | ERROR_RATE_FAILED_THRESH |          | ERROR_RATE_DEGRADED_THRESH |    |
|    | R/W-FFh                  |          | R/W-FFh                    |    |
| 15 |                          |          |                            | 0  |
|    |                          | Reserved |                            |    |
|    |                          | R-0000h  |                            |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 175. Port Error Rate Threshold CSR n (SPn\_ERR\_THRESH) Field Descriptions

| Bit   | Field                      | Value | Description                                                                                            |
|-------|----------------------------|-------|--------------------------------------------------------------------------------------------------------|
| 31–24 | ERROR_RATE_FAILED_THRESH   |       | These bits provide the threshold value for reporting an error condition due to a possibly broken link. |
|       |                            | 00h   | Disable the error rate register                                                                        |
|       |                            | 01h   | Set the error reporting threshold to 1                                                                 |
|       |                            | 02h   | Set the error reporting threshold to 2                                                                 |
|       |                            |       |                                                                                                        |
|       |                            | FFh   | Set the error reporting threshold to 255                                                               |
| 23–16 | ERROR_RATE_DEGRADED_THRESH |       | These bits provide the threshold value for reporting an error condition due to a degrading link.       |
|       |                            | 00h   | Disable the error rate Register                                                                        |
|       |                            | 01h   | Set the error reporting threshold to 1                                                                 |
|       |                            | 02h   | Set the error reporting threshold to 2                                                                 |
|       |                            |       |                                                                                                        |
|       |                            | FFh   | Set the error reporting threshold to 255                                                               |
| 15–0  | Reserved                   | 0000h | These read-only bits return 0s when read.                                                              |



# 5.91 Port IP Discovery Timer for 4x Mode Register (SP\_IP\_DISCOVERY\_TIMER)

The port IP discovery timer for 4x mode register (SP\_IP\_DISCOVERY\_TIMER) is shown in Figure 154 and described in Table 176.

### Figure 154. Port IP Discovery Timer for 4x Mode Register (SP\_IP\_DISCOVERY\_TIMER) - Address Offset 12000h

| 31 | 28              | 27 24    | 23 20    | ) 19 16  |
|----|-----------------|----------|----------|----------|
|    | DISCOVERY_TIMER | Reserved | PW_TIMER | Reserved |
|    | R/W-9h          | R-0h     | R/W-8h   | R-0h     |
| 15 |                 |          |          | 0        |
|    |                 | Rese     | erved    |          |
|    | R-0000h         |          |          |          |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 176. Port IP Discovery Timer for 4x Mode Register (SP\_IP\_DISCOVERY\_TIMER) Field Descriptions

| Bit                   | Field    | Value | Description                                                                                                                                                                                           |
|-----------------------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–28 DISCOVERY_TIMER |          |       | Discovery timer for 4x mode. The discovery timer allows time for the link partner to enter its DISCOVERY state and if the link partner is supporting 4x mode, for all 4 lanes to be aligned.          |
|                       |          | 0000b | Reserved                                                                                                                                                                                              |
|                       |          | 0001b | 0.84 ms                                                                                                                                                                                               |
|                       |          | 0010b | 0.84 ms x 2 = 1.68 ms                                                                                                                                                                                 |
|                       |          |       |                                                                                                                                                                                                       |
|                       |          | 1001b | 0.84 ms x 9= 7.56 ms (default)                                                                                                                                                                        |
|                       |          |       |                                                                                                                                                                                                       |
|                       |          | 1111b | 0.84 ms x 15= 12.6 ms                                                                                                                                                                                 |
| 27–24                 | Reserved | 0000b | These read-only bits return 0s when read.                                                                                                                                                             |
| 23–20                 | PW_TIMER |       | Port-write timer. The timer defines a period to repeat sending an error reporting port-write request for software assistance. The timer is stopped by software writing to the error detect registers. |
|                       |          | 0000b | Disabled. Port-write is sent once only.                                                                                                                                                               |
|                       |          | 0001b | 107 ms–214 ms                                                                                                                                                                                         |
|                       |          | 0010b | 214 ms-321 ms                                                                                                                                                                                         |
|                       |          | 0100b | 428 ms-535 ms                                                                                                                                                                                         |
|                       |          | 1000b | 856 ms-963 ms (default)                                                                                                                                                                               |
|                       |          | Other | Reserved                                                                                                                                                                                              |
| 19–0                  | Reserved | 0000h | These read-only bits return 0s when read.                                                                                                                                                             |

# 5.92 Port IP Mode CSR (SP\_IP\_MODE)

The port IP mode CSR (SP\_IP\_MODE) is shown in Figure 155 and described in Table 177. For additional programming information, see Section 2.3.13.2.

### Figure 155. Port IP Mode CSR (SP\_IP\_MODE) - Address Offset 12004h

| 31    | 30  | 29                   | 28                     | 27         | 26             | 25           | 24 |       |             |              |            |            |           | 16         |
|-------|-----|----------------------|------------------------|------------|----------------|--------------|----|-------|-------------|--------------|------------|------------|-----------|------------|
| SP_MC | DDE | IDLE_<br>ERR_<br>DIS | TX_<br>FIFO_<br>BYPASS | PW_<br>DIS | TGT_<br>ID_DIS | SELF_<br>RST |    |       |             | Res          | erved      |            |           |            |
| R/W-  | -0  | R/W-0                | R/W-0                  | R/W-0      | R-0            | R/W-0        |    |       |             | F            | R-0        |            |           |            |
| 15    |     |                      |                        |            |                |              |    | 6     | 5           | 4            | 3          | 2          | 1         | 0          |
|       |     |                      | F                      | Reserved   | 1              |              |    |       | MLTC_<br>EN | MLTC_<br>IRQ | RST_<br>EN | RST_<br>CS | PW_<br>EN | PW_<br>IRQ |
| R-0   |     |                      |                        |            |                |              |    | R/W-0 | R/W-0       | R/W-0        | R/W-0      | R/W-0      | R/W-0     |            |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 177. Port IP Mode CSR (SP\_IP\_MODE) Field Descriptions

| Bit   | Field          | Value | Description                                                                                                                                                                                                                                                             |
|-------|----------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30 | SP_MODE        |       | SRIO port IP mode of operation                                                                                                                                                                                                                                          |
|       |                | 00b   | RapidIO Physical Layer 1x/4x LP-Serial Specification                                                                                                                                                                                                                    |
|       |                | 01b   | 4 ports (1x mode each)                                                                                                                                                                                                                                                  |
|       |                | 10b   | Reserved                                                                                                                                                                                                                                                                |
|       |                | 11b   | Reserved                                                                                                                                                                                                                                                                |
| 29    | IDLE_ERR_DIS   |       | Idle error checking disable                                                                                                                                                                                                                                             |
|       |                | 0     | Error checking enabled (default), only  K ,  A  and  R  characters are available. If input receives any other characters in idle sequence, it should enter the Input-Error-stopped state.                                                                               |
|       |                | 1     | Error checking disabled, all not idle or invalid characters during idle sequence are ignored                                                                                                                                                                            |
| 28    | TX_FIFO_BYPASS |       | Transmit FIFO bypass                                                                                                                                                                                                                                                    |
|       |                | 0     | The TX_FIFO is operational (default)                                                                                                                                                                                                                                    |
|       |                | 1     | The TX_FIFO is bypassed. The txbclk and the sys_clk must be locked during operation, but the phase variation up to 1 clock cycle is allowable. The 4 deep FIFO is used to accommodate the phase difference.                                                             |
| 27    | PW_DIS         |       | Port-write error reporting disable.                                                                                                                                                                                                                                     |
|       |                | 0     | Enable Port-Write Error reporting (default)                                                                                                                                                                                                                             |
|       |                | 1     | Disable Port-Write Error reporting                                                                                                                                                                                                                                      |
| 26    | TGT_ID_DIS     |       | Destination ID Decode Disable- Definition of packet acceptance by the physical layer.                                                                                                                                                                                   |
|       |                | 0     | Packet accepted if DestID = Base ID. When DestID is not equal to Base ID, the packet is ignored; i.e., it is accepted by RapidIO port but is not forwarded to logical layer.                                                                                            |
|       |                | 1     | Packet accepted with any DestID and forwarded to the logical layer.                                                                                                                                                                                                     |
| 25    | SELF_RST       |       | Self reset interrupt enable, when 4 link-request reset control symbols are accepted.                                                                                                                                                                                    |
|       |                | 0     | Self reset interrupt disabled (default), interrupt signal is asserted                                                                                                                                                                                                   |
|       |                | 1     | Self reset interrupt enabled, the reset signal is asserted by the reset controller. When the SELF_RST is set to 1, the SERDES macro resets and all register values from address offset 1000h and higher are returned to default value. All initialized values are lost. |
| 24–6  | Reserved       | 0     | These read-only bits return 0s when read.                                                                                                                                                                                                                               |
| 5     | MLTC_EN        |       | Multicast-Event Interrupt Enable. If enabled, the interrupt signal is High when the Multicast-Event control symbol is received by any port.                                                                                                                             |
|       |                | 0     | Multicast interrupt disable                                                                                                                                                                                                                                             |
|       |                | 1     | Multicast interrupt enable                                                                                                                                                                                                                                              |
| 4     | MLTC_IRQ       |       | Multicast-event interrupt status. Once set, the MLTC_IRQ bit remains set until software writes a 1 to it. The mltc_irq output signal is driven by this bit.                                                                                                             |
|       |                | 0     | The multicast event control symbol has not been received by any of the ports.                                                                                                                                                                                           |
|       |                | 1     | The multicast-event control symbol has been received by one of the ports.                                                                                                                                                                                               |



| Bit | Field  | Value | Description                                                                                                                                                      |
|-----|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RST_EN |       | Reset Interrupt Enable. If enabled, the interrupt signal is High when the 4 reset control symbols are received in a sequence                                     |
|     |        | 0     | Reset interrupt disable                                                                                                                                          |
|     |        | 1     | Reset interrupt enable                                                                                                                                           |
| 2   | RST_CS |       | Reset received status bit. It is set when Once set, the RST_CS bit remains set until software writes a 1 to it. The rst_irq output signal is driven by this bit. |
|     |        | 0     | Four reset control symbols have not been received in a sequence.                                                                                                 |
|     |        | 1     | Four reset control symbols have been received in a sequence.                                                                                                     |
| 1   | PW_EN  |       | Port-Write-In Interrupt Enable. If enabled, the interrupt signal is High when the Port-Write-In request is received                                              |
|     |        | 0     | Port-Write-In interrupt disable                                                                                                                                  |
|     |        | 1     | Port-Write-In interrupt enable                                                                                                                                   |
| 0   | PW_IRQ |       | Port-Write-In request interrupt. Once set, the PW_IRQ bit remains set until software writes a 1 to it. The pw_irq output signal is driven by this bit.           |
|     |        | 0     | The Port-Write-In request has not been received.                                                                                                                 |
|     |        | 1     | The Port-Write-In request has been received. The payload is captured.                                                                                            |

# Table 177. Port IP Mode CSR (SP\_IP\_MODE) Field Descriptions (continued)

# 5.93 Port IP Prescaler Register (IP\_PRESCAL)

The port IP prescaler register (IP\_PRESCAL) is shown in Figure 156 and described in Table 178. This register defines a prescaler for different frequencies of the DMA clock. The purpose of this register is to keep the timers of SP\_LT\_CTL (offset 01120h), SP0\_ERR\_RATE through SP3\_ERR\_RATE (offsets 02068h, 020A8h, 020E8, and 02128h), SP\_IP\_DISCOVERY\_TIMER (offset 12000h), and SP0\_SILENCE\_TIMER through SP3\_SILENCE\_TIMER (offsets 14008h, 14108h, 14208h, and 14308h) within the same range for different frequencies of the DMA clock.

### Figure 156. Port IP Prescaler Register (IP\_PRESCAL) - Address Offset 12008h

| 31 |          |      |       |          | 16 |
|----|----------|------|-------|----------|----|
|    |          | Rese | erved |          |    |
|    |          | R-00 | )00h  |          |    |
| 15 |          | 8    | 7     |          | 0  |
|    | Reserved |      |       | PRESCALE |    |
|    | R-00h    |      |       | RW-0Fh   |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

| Bit  | Field    | Value   | Description                                                                                                                                           |
|------|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8 | Reserved | 000000h | These read-only bits return 0s when read.                                                                                                             |
| 7–0  | PRESCALE |         | For different frequencies of the DMA clock, use the following formula to get the prescaler value in decimal, where the DMA clock frequency is in MHz: |
|      |          |         | DMA clock frequency x 16                                                                                                                              |
|      |          |         | 156.25 – 1                                                                                                                                            |
|      |          | 06h     | 66.67 MHz                                                                                                                                             |
|      |          |         |                                                                                                                                                       |
|      |          | 09h     | 100 MHz                                                                                                                                               |
|      |          |         |                                                                                                                                                       |
|      |          | 0Fh     | 156.25 MHz                                                                                                                                            |
|      |          | 10h     | 166.67 MHz                                                                                                                                            |
|      |          |         |                                                                                                                                                       |
|      |          | 18h     | 250 MHz                                                                                                                                               |
|      |          |         |                                                                                                                                                       |
|      |          | 21h     | 333 MHz                                                                                                                                               |

### Table 178. Port IP Prescaler Register (IP\_PRESCAL) Field Descriptions



# 5.94 Port-Write-In Capture CSRs (SP\_IP\_PW\_IN\_CAPT[0-3])

Four registers are used to capture the incoming 128-bit payload of a Port-Write. These four registers are shown in Figure 157. As can be seen in Table 179, each of the registers captures one of the four 32-bit words of the payload.

### Figure 157. Port-Write-In Capture CSRs

Port-Write-In Capture CSR 0 (SP\_IP\_PW\_IN\_CAPT0) - Address Offset 12010h

| 31                                                                      | 0 |
|-------------------------------------------------------------------------|---|
| PW_CAPT0                                                                |   |
| R-0000000h                                                              |   |
| Port-Write-In Capture CSR 1 (SP_IP_PW_IN_CAPT1) - Address Offset 12014h |   |
| 31                                                                      | 0 |
| PW_CAPT1                                                                |   |
| R-0000000h                                                              |   |
| Port-Write-In Capture CSR 0 (SP_IP_PW_IN_CAPT0) - Address Offset 12018h |   |
| 31                                                                      | 0 |
| PW_CAPT2                                                                |   |

Port-Write-In Capture CSR 0 (SP\_IP\_PW\_IN\_CAPT0) - Address Offset 1201Ch

| 31 0       |  |
|------------|--|
| PW_CAPT3   |  |
| R-0000000h |  |

R-0000000h

LEGEND: R = Read only; -n = Value after reset

### Table 179. Port-Write-In Capture CSR Field Descriptions

| Field    | Value                       | Description                                        |
|----------|-----------------------------|----------------------------------------------------|
| PW_CAPT0 | 00000000h<br>to<br>FFFFFFFh | Word 0 (bits 0 to 31) of the Port-Write payload.   |
| PW_CAPT1 | 00000000h<br>to<br>FFFFFFFh | Word 1 (bits 32 to 63) of the Port-Write payload.  |
| PW_CAPT2 | 00000000h<br>to<br>FFFFFFFh | Word 2 (bits 64 to 95) of the Port-Write payload.  |
| PW_CAPT3 | 00000000h<br>to<br>FFFFFFFh | Word 3 (bits 96 to 127) of the Port-Write payload. |

# 5.95 Port Reset Option CSR n (SPn\_RST\_OPT)

Each of the four ports is supported by a register of this type (see Table 180). SPn\_RST\_OPT is shown in Figure 158 and described in Table 181.

| Table 180. SPn_RST_OPT Registers and the Associated Ports |                |                 |  |  |  |
|-----------------------------------------------------------|----------------|-----------------|--|--|--|
| Register                                                  | Address Offset | Associated Port |  |  |  |
| SP0_RST_OPT                                               | 14000h         | Port 0          |  |  |  |
| SP1_RST_OPT                                               | 14100h         | Port 1          |  |  |  |
| SP2_RST_OPT                                               | 14200h         | Port 2          |  |  |  |
| SP3_RST_OPT                                               | 14300h         | Port 3          |  |  |  |

### -----. . . . . -

### Figure 158. Port Reset Option CSR n (SPn\_RST\_OPT)

| 31 |          |        |         | 16 |
|----|----------|--------|---------|----|
|    |          | Reserv | ved     |    |
|    |          | R-000  | Oh      |    |
| 15 |          | 8 7    |         | 0  |
|    | Reserved |        | PORT_ID |    |
|    | R-00h    |        | R-imp   |    |

LEGEND: R = Read only; -n = Value after reset; -imp = Value after reset is implementation defined.

### Table 181. Port Reset Option CSR n (SPn\_RST\_OPT) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                               |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8 | Reserved | 0     | These read-only bits return 0s when read.                                                                                                                                                                                                 |
| 7–0  | PORT_ID  |       | Port ID defines unique number for port in Switch. The Port ID is used for port-write request. The ID coincides with ISF port of connection. Example: 00_0000_01 _ port 1 ( Impl.: IP0, port 1) 00_0001_11 _ port 7 ( Impl.: IP1, port 3). |



### 5.96 Port Control Independent Register n (SPn\_CTL\_INDEP)

Each of the four ports is supported by a register of this type (see Table 182). The port control independent register n (SP $n_CTL_INDEP$ ) is shown in Figure 159 and described in Table 183.

| Register      | Address Offset | Associated Port |  |
|---------------|----------------|-----------------|--|
| SP0_CTL_INDEP | 14004h         | Port 0          |  |
| SP1_CTL_INDEP | 14104h         | Port 1          |  |
| SP2_CTL_INDEP | 14204h         | Port 2          |  |
| SP3_CTL_INDEP | 14304h         | Port 3          |  |

### Figure 159. Port Control Independent Register n (SPn\_CTL\_INDEP)

| 31       | 30               | 29               | 28                | 27      | 26           | 25               | 24                |
|----------|------------------|------------------|-------------------|---------|--------------|------------------|-------------------|
| Reserved | TX_FLW           | SOFT_REC         | Reser             | ved     | FORCE_REINIT | TRANS            | S_MODE            |
| R-0      | R/W-0            | R/W-0            | R-C               | )       | W-0          | R/\              | V-01              |
| 23       | 22               | 21               | 20                | 19      | 18           | 17               | 16                |
| DEBUG    | SEND_DBG_<br>PKT | ILL_TRANS_<br>EN | ILL_TRANS_<br>ERR |         |              | MAX_RETRY_<br>EN | MAX_RETRY_<br>ERR |
| R/W-0    | R/W-0            | R/W-0            | R/W-0             |         | R-0          | R/W-0            | R/W-0             |
| 15       |                  |                  |                   |         |              |                  | 8                 |
|          |                  |                  | MAX_RE            | TRY_THR |              |                  |                   |
|          |                  |                  | R/W               | /-00h   |              |                  |                   |
| 7        | 6                | 5                |                   |         |              |                  | 0                 |
| IRQ_EN   | IRQ_ERR          |                  |                   | R       | eserved      |                  |                   |
| R/W-0    | R/W-0            |                  |                   |         | R-0          |                  |                   |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 183. Port Control Independent Register *n* (SP*n*\_CTL\_INDEP) Field Descriptions

| Bit   | Field        | Value | Description                                                                                                                                                                                                                                                                                                                               |
|-------|--------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved     | 0     | This read-only bit returns 0 when read.                                                                                                                                                                                                                                                                                                   |
| 30    | TX_FLW       |       | Transmit Link Flow Control enable                                                                                                                                                                                                                                                                                                         |
|       |              | 0     | Disables transmit flow control (Enables receive link flow control)                                                                                                                                                                                                                                                                        |
|       |              | 1     | Reserved                                                                                                                                                                                                                                                                                                                                  |
| 29    | SOFT_REC     |       | Software controlled error recovery                                                                                                                                                                                                                                                                                                        |
|       |              | 0     | Transmission of error recovery sequence is performed by the hardware                                                                                                                                                                                                                                                                      |
|       |              | 1     | Transmission of error recovery sequence is performed by the software. By default the transmission error recovery sequence is performed by the hardware. If this bit is set, the hardware recovery is disabled and the hardware transmission logic must wait until software has written the register Port <i>n</i> Local ackID Status CSR. |
| 28–27 | Reserved     | 0     | These read-only bits return 0s when read.                                                                                                                                                                                                                                                                                                 |
| 26    | FORCE_REINIT |       | Force reinitialization process. In 4x mode this bit affects all 4 lanes. This bit is write only, and reads always return 0.                                                                                                                                                                                                               |
| 25–24 | TRANS_MODE   |       | Describes the transfer mode for each port.                                                                                                                                                                                                                                                                                                |
|       |              | 00b   | Reserved (Cut-Through Mode)                                                                                                                                                                                                                                                                                                               |
|       |              | 01b   | Store & Forward Mode                                                                                                                                                                                                                                                                                                                      |
|       |              | 1xb   | Reserved                                                                                                                                                                                                                                                                                                                                  |

# Table 183. Port Control Independent Register *n* (SP*n*\_CTL\_INDEP) Field Descriptions (continued)

| Bit   | Field         | Value | Description                                                                                                                                                                                                  |
|-------|---------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | DEBUG         |       | Mode of operation.                                                                                                                                                                                           |
|       |               | 0     | Normal mode                                                                                                                                                                                                  |
|       |               | 1     | Debug mode. The debug mode unlocks capture registers for write and enable debug packet generator feature.                                                                                                    |
| 22    | SEND_DBG_PKT  |       | Send debug packet. Write 1 to force the sending of a debug packet. This bit is set by software and cleared after debug packet is sent. Writes when the bit is set are ignored. Debug mode only.              |
| 21    | ILL_TRANS_EN  |       | Illegal transfer error reporting enable. If enabled, the Port-Write and interrupt are reported errors.                                                                                                       |
|       |               | 0     | Disable illegal transfer error reporting.                                                                                                                                                                    |
|       |               | 1     | Enable illegal transfer error reporting.                                                                                                                                                                     |
| 20    | ILL_TRANS_ERR |       | Illegal Transfer Error. After being set, the ILL_TRANS_ERR bit remains set until written with a 1, or until a value of all 0s is written to the register SP0_ERR_DET.                                        |
|       |               | 0     | No error condition detected                                                                                                                                                                                  |
|       |               | 1     | One of the following error conditions has been detected:                                                                                                                                                     |
|       |               |       | The received transaction has a reserved value in the tt field.                                                                                                                                               |
|       |               |       | A reserved field of Maintenance transaction type is detected.                                                                                                                                                |
|       |               |       | The destination ID is not defined in look-up table. This error is also reported in registers SP0_ERR_DET and ERR_DET.                                                                                        |
| 19–18 | Reserved      | 0     | These read-only bits return 0s when read.                                                                                                                                                                    |
| 17    | MAX_RETRY_EN  |       | Maximum retry error reporting enable. If enabled, the Port-Write and interrupt a reported as errors.                                                                                                         |
|       |               | 0b    | Max retry error report disable                                                                                                                                                                               |
|       |               | 1b    | Max retry error report enable                                                                                                                                                                                |
| 16    | MAX_RETRY_ERR |       | Maximum retry error. This bit is ignored if max_retry_threshold is 0. Once set, the MAX_RETRY_ERR bit remains set until written with a 1, or until a value of all 0s is written to the register SP0_ERR_DET. |
|       |               | 0     | No error condition detected                                                                                                                                                                                  |
|       |               | 1     | max_retry_cnt is equal to max_retry_threshold. The Port-Write request and interrupt are generated if enabled. This error is also reported in the register SP0_ERR_DET.                                       |
| 15–8  | MAX_RETRY_THR |       | Maximum Retry Threshold Trigger. These bits provide the threshold value for reporting an error condition due to possibly broken partner behavior.                                                            |
|       |               | 00h   | Disable the max_retry_error reporting                                                                                                                                                                        |
|       |               | 01h   | Set the max_retry_threshold to 1                                                                                                                                                                             |
|       |               | 02h   | Set the max_retry_threshold to 2                                                                                                                                                                             |
|       |               |       |                                                                                                                                                                                                              |
|       |               | FFh   | Set the max_retry_threshold to 255                                                                                                                                                                           |
| 7     | IRQ_EN        |       | Interrupt error reporting enable. If enabled, the interrupt signal is high when the IRQ_ERR is set to 1.                                                                                                     |
|       |               | 0     | Interrupt error report disable                                                                                                                                                                               |
|       |               | 1     | Interrupt error report enable                                                                                                                                                                                |
| 6     | IRQ_ERR       |       | Interrupt error status                                                                                                                                                                                       |
|       |               | 0     | An error has not occurred and/or there is not a Port-Write condition.                                                                                                                                        |
|       |               | 1     | An error occurred and there is a Port-Write condition. IRQ_ERR remains at 1                                                                                                                                  |
|       |               | •     | until software writes a 1 to it.                                                                                                                                                                             |



# 5.97 Port Silence Timer n Register (SPn\_SILENCE\_TIMER)

Each of the four ports is supported by a register of this type (see Table 184). The port silence timer n register (SPn\_SILENCE\_TIMER) is shown in Figure 160 and described in Table 185.

### Table 184. SPn\_SILENCE\_TIMER Registers and the Associated Ports

| Register          | Address Offset | Associated Port |  |
|-------------------|----------------|-----------------|--|
| SP0_SILENCE_TIMER | 14008h         | Port 0          |  |
| SP1_SILENCE_TIMER | 14108h         | Port 1          |  |
| SP2_SILENCE_TIMER | 14208h         | Port 2          |  |
| SP3_SILENCE_TIMER | 14308h         | Port 3          |  |

# Figure 160. Port Silence Timer n Register (SPn\_SILENCE\_TIMER) 31 28 27 16 SILENCE\_TIMER Reserved 16 R/W-Bh R-0 0 15 Reserved 0 Reserved R-0 0 Reserved R-0 0

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 185. Port Silence Timer n Register (SPn\_SILENCE\_TIMER) Field Descriptions

| Bit   | Field         | Value | Description                                                      |
|-------|---------------|-------|------------------------------------------------------------------|
| 31–28 | SILENCE_TIMER |       | Silence timer. Defines the time of the port in the SILENT state. |
|       |               | 0000b | 64 ns for debug                                                  |
|       |               | 0001b | 13.1 μs                                                          |
|       |               | 0010b | 13.1 μs x 2 = 26.2 μs                                            |
|       |               |       |                                                                  |
|       |               | 1011b | 13.1 μs x 11 = 144.1 μs default                                  |
|       |               |       |                                                                  |
|       |               | 1111b | 13.1 μs x 15= 196.5 μs                                           |
| 27–0  | Reserved      | 0     | These read-only bits return 0s when read.                        |

# 5.98 Port Multicast-Event Control Symbol Request Register n (SPn\_MULT\_EVNT\_CS)

Each of the four ports is supported by a register of this type (see Table 186). The port multicast-event control symbol request register n (SPn\_MULT\_EVNT\_CS) is shown in Figure 161 and described in Table 187

| Table 186. SP <i>n_</i> MULT_EVNT_CS Registers and the Associated Ports |                |                 |  |  |  |  |
|-------------------------------------------------------------------------|----------------|-----------------|--|--|--|--|
| Register                                                                | Address Offset | Associated Port |  |  |  |  |
| SP0_MULT_EVNT_CS                                                        | 1400Ch         | Port 0          |  |  |  |  |
| SP1_MULT_EVNT_CS                                                        | 1410Ch         | Port 1          |  |  |  |  |
| SP2_MULT_EVNT_CS                                                        | 1420Ch         | Port 2          |  |  |  |  |
| SP3_MULT_EVNT_CS                                                        | 1430Ch         | Port 3          |  |  |  |  |

### Figure 161. Port Multicast-Event Control Symbol Request Register n (SPn\_MULT\_EVNT\_CS)

| 31 | 0            |
|----|--------------|
|    | MULT_EVNT_CS |
|    | W-0          |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 187. Port Multicast-Event Control Symbol Request Register n (SPn\_MULT\_EVNT\_CS) Field Descriptions

| Bit  | Field        | Value | Description                                                          |
|------|--------------|-------|----------------------------------------------------------------------|
| 31–0 | MULT_EVNT_CS |       | Write to send Control Symbol, data is ignored. Reads return 000000h. |



# 5.99 Port Control Symbol Transmit n Register (SPn\_CS\_TX)

Each of the four ports is supported by a register of this type (see Table 188). The port control symbol transmit *n* register (SPn\_CS\_TX) is shown in Figure 162 and described in Table 189.

| Table 188. SP <i>n</i> _CS | _TX Registers and the Associated Ports |
|----------------------------|----------------------------------------|
|----------------------------|----------------------------------------|

| Register  | Address Offset | Associated Port |  |
|-----------|----------------|-----------------|--|
| SP0_CS_TX | 14014h         | Port 0          |  |
| SP1_CS_TX | 14114h         | Port 1          |  |
| SP2_CS_TX | 14214h         | Port 2          |  |
| SP3_CS_TX | 14314h         | Port 3          |  |

### Figure 162. Port Control Symbol Transmit *n* Register (SPn\_CS\_TX)

| 31 |         | 29 | 28     |    |       | 24 23 |          | 19 | 18      | 16 |
|----|---------|----|--------|----|-------|-------|----------|----|---------|----|
|    | STYPE_0 |    |        |    | PAR_0 |       | PAR_1    |    | STYPE_1 |    |
|    | R/W-0   |    |        |    | R/W-0 |       | R/W-0    |    | R/W-0   |    |
| 15 |         | 13 | 12     | 11 |       |       |          |    |         | 0  |
|    | CMD     |    | CS_EMB |    |       |       | Reserved |    |         |    |
|    | R/W-0   |    | R/W-0  |    |       |       | R-0      |    |         |    |

LEGEND: R/W = Read/Write; R = Read only; -n = Value after reset

### Table 189. Port Control Symbol Transmit *n* Register (SPn\_CS\_TX) Field Descriptions

| Bit   | Field    | Value | Description                                                                                  |  |
|-------|----------|-------|----------------------------------------------------------------------------------------------|--|
| 31–29 | STYPE_0  |       | Encoding for control symbol that makes use of parameters PAR_0 and PAR_1.                    |  |
| 28–24 | PAR_0    |       | Used in conjunction with stype0 encoding.                                                    |  |
| 23–19 | PAR_1    |       | Used in conjunction with stype0 encoding.                                                    |  |
| 18–16 | STYPE_1  |       | Encoding for control symbol that makes use of parameter CMD.                                 |  |
| 15–13 | CMD      |       | Used in conjunction with stype1 encoding to define the link maintenance commands.            |  |
| 12    | CS_EMB   |       | When set, forces the outbound flow to insert control symbol into packet. Used in debug mode. |  |
| 11–0  | Reserved | 0     | These read-only bits return 0s when read.                                                    |  |



# Index

1x/4x LP serial port maintenance block header register 196 1x/4x mode selection field for ports 231 1X\_MODE field of PER\_SET\_SNTL 113 2 MSBs of address for LSUn 159 4x/1x mode selection field for ports 231 4x mode data path in SRIO component block diagram 26 discovery timer period field 230 8-bit/10-bit coding and decoding 21 8BIT\_DEVID\_LOW\_BOUND field of PF\_8B\_CNTL 124 8BIT\_DEVID\_UP\_BOUND field of PF\_8B\_CNTL 124 8-bit device IDs lower boundary for packet forwarding 124 node ID field to compare to incoming destination ID 122 node ID field to supply outgoing source ID 121 upper boundary for packet forwarding 124 8-bit node ID field to compare to incoming destination ID 122 to supply outgoing source ID 121 8BNODEID field of DEVICEID\_REG1 121 8BNODEID field of DEVICEID\_REG2 122 16BIT\_DEVID\_LOW\_BOUND field of PF\_16B\_CNTLn 123 16BIT\_DEVID\_UP\_BOUND field of PF\_16B\_CNTLn 123 16-bit device IDs lower boundary for packet forwarding 123 node ID field to compare to incoming destination ID 122 node ID field to supply outgoing source ID 121 upper boundary for packet forwarding 123 16-bit node ID field to compare to incoming destination ID 122 to supply outgoing source ID 121 16BNODEID field of DEVICEID\_REG1 121 16BNODEID field of DEVICEID\_REG2 122 Α ACKID STATUS field of SPn LM RESP 201

acknowledge control symbol overdue at port n rate counting enable field 222 status field 220 acknowledge control symbols in SRIO operation sequence 22 acknowledge IDs ackID status field for link response 201

next expected ackID field 202 output port next transmitted ackID field 202 output port unacknowledged ackID status field 202 unexpected ackID in control symbol at port n rate counting enable field 221 status field 219 unexpected ackID in packet at port n rate counting enable field 222 status field 220 adaptive equalizer control field 125 ADDR CAPT 215 ADDRESS 31 3 field of ADDR CAPT 215 ADDRESS\_63\_32 field of H\_ADDR\_CAPT 214 ADDRESS\_LSB/CONFIG\_OFFSET field of LSUn\_REG1 156 ADDRESS\_MSB field of LSUn\_REG0 155 address associated with logical/transport error LSBs 215 MSBs 214 address capture CSRs for logical/transport errors 214, 215 address LSBs for LSUn destination 156 address MSBs for LSUn destination 155 ALIGN field of SERDES\_CFGRXn\_CNTL 125 amplitude reduction (de-emphasis) field 128 ASBLY\_ID 184 ASBLY\_INFO 185 assembly identity CAR 184 assembly information CAR 185 ASSY IDENTITY field of ASBLY ID 184 ASSY\_VENDORIDENTITY field of ASBLY\_ID 184 ASSYREV field of ASBLY\_INFO 185 ATOMIC\_CLEAR field of DEST\_OP 189 ATOMIC\_CLEAR field of SRC\_OP 188 ATOMIC\_DCRMNT field of DEST\_OP 189 ATOMIC\_DCRMNT field of SRC\_OP 188 ATOMIC INCRMNT field of DEST OP 189 ATOMIC\_INCRMNT field of SRC\_OP 188 ATOMIC\_SET field of DEST\_OP 189 ATOMIC\_SET field of SRC\_OP 188 ATOMIC\_TEST\_AND\_SWAP field of DEST\_OP 189 ATOMIC\_TEST\_AND\_SWAP field of SRC\_OP 188 Atomic operations overview 65 packet Ftypes and Ttypes 25 Atomic operations support for destination device 189 Atomic operations support for source device 188

В bad CRC in control symbol at port n rate counting enable field 221 status field 219 bad CRC in packet at port n rate counting enable field 222 status field 220 bandwidth per differential pair based on 1x/4x LP-Serial specification 18 BASE\_DEVICEID field of BASE\_ID 193 BASE\_ID 193 base address registers for local configuration space 191, 192 base device ID CSR 193 base device ID for host PE 194 Big Endian versus Little Endian 68 binary notational convention 14 BLK0\_EN\_STAT field of GBL\_EN\_STAT 117 BLK1\_EN\_STAT field of GBL\_EN\_STAT 117 BLK2\_EN\_STAT field of GBL\_EN\_STAT 117 BLK3\_EN\_STAT field of GBL\_EN\_STAT 117 BLK4\_EN\_STAT field of GBL\_EN\_STAT 117 BLK5\_EN\_STAT field of GBL\_EN\_STAT 117 BLK6\_EN\_STAT field of GBL\_EN\_STAT 117 BLK7\_EN\_STAT field of GBL\_EN\_STAT 117 BLK8\_EN\_STAT field of GBL\_EN\_STAT 117 BLKn\_EN 119 BLKn\_EN\_STAT 120 block 0 enable status bit 118 block 1 enable status bit 117 block 2 enable status bit 117 block 3 enable status bit 117 block 4 enable status bit 117 block 5 enable status bit 117 block 6 enable status bit 117 block 7 enable status bit 117 block 8 enable status bit 117 block diagram of SRIO components 26 block diagram of SRIO peripheral 21 block enable registers 119 block enable status registers 120 BOOT\_COMPLETE field of PER\_SET\_CNTL 113 bootloading access to read-only registers 113 configuration and operation 79 data movement 80 device wakeup afterwards 80 BRIDGE field of PE\_FEAT 186 bridge present field 186 BSY field of LSUn REG6 161 buffer pointer field of RX buffer descriptor 47 buffer\_pointer field of TX buffer descriptor 52 BUSWIDTH field of SERDES\_CFGRXn\_CNTL 125 BUSWIDTH field of SERDES\_CFGTXn\_CNTL 128 busy (BSY) signal of an LSU 39 busy status field for LSUn 161

BYTE\_COUNT field of LSUn\_REG3 158

### С

CAPTURE0 field of SPn\_ERR\_CAPT\_DBG1 224 CAPTURE1 field of SPn\_ERR\_CAPT\_DBG2 225 CAPTURE2 field of SPn\_ERR\_CAPT\_DBG3 226 CAPTURE3 field of SPn ERR CAPT DBG4 227 CAPTURE VALID INFO field of SPn\_ERR\_ATTR\_CAPT\_DBG0 223 CBA\_TRANS\_PRI field of PER\_SET\_CNTL 113 cc field of RX buffer descriptor 47 cc field of TX buffer descriptor 52 CDR field of SERDES CFGRXn CNTL 125 CLASS field of PID 111 clearing interrupt conditions 86 clear registers for CPPI interrupt conditions 135, 137 for doorbell interrupt conditions 133 for error, reset, and special event (port) interrupt conditions 143 for LSU interrupt conditions 141 clock/data recovery field 125 clock domains 21 clock prescaler field 233 clock recovery 21 CMD field of SPn\_CS\_TX 240 CM field of SERDES CFGTXn CNTL 128 CNTL\_SYM\_UNEXPECTED\_ACKID\_EN field of SPn\_RATE\_EN 221 CNTL SYM UNEXPECTED ACKID field of SPn\_ERR\_DET 219 command control symbol field for port n 240 COMMAND field of SPn\_LM\_REQ 200 command status (completion code) field for LSUn 161 common mode field 128 common transport large system support field 186 Communications Port Programming Interface. See CPPI 43 COMP\_TAG 195 COMPLETION\_CODE field of LSUn\_REG6 161 completion pointer for RX queue n 167 completion pointer for TX queue n 165 COMPONENT\_TAG field of COMP\_TAG 195 configuration offset field for LSUn 156 configuring SERDES macros 28 congestion control 65 basic scheme 66 congestion control packet (CCP) Ftype and Ttype 25 congestion control packet (CCP) purpose 65 count of Xoff congestion control packets 66 flow control destination IDs 66 flow masks 67 time-out timer 66 control capture CSR for logical/transport errors 217 control information field for port n error capture 224 control symbols acknowledge or link-response control symbol overdue

at port n rate counting enable field 222 status field 220 bad CRC in control symbol at port n rate counting enable field 221 status field 219 detect 4 reset control symbols at port 232 detect multicast-event control symbol at port 231 enable interrupt if 4 reset control symbols received at port 232 enable interrupt if multicast-event control symbol received at port 231 force insertion of control symbol in outbound packet 240 initiate self reset interrupt if 4 link-request control symbols accepted 231 introduction 24 link maintenance command field for port n 240 link maintenance request control symbol generation register 200 packet-not-accepted control symbol at port n rate counting enable field 221 status field 220 parameter0 field for port n 240 parameter1 field for port n 240 port multicast-event control symbol request field 239 stype0 field for port n 240 stype1 field for port n 240 transmit request field for port n 240 unexpected ackID in control symbol at port n rate counting enable field 221 status field 219 unexpected acknowledge control symbol at port n rate counting enable field 222 status field 220 unexpected control symbol at port n rate counting enable field 222 status field 220 CORRUPT\_CNTL\_SYM\_EN field of SPn\_RATE\_EN 221 CORRUPT\_CNTL\_SYM field of SPn\_ERR\_DET 219 corrupt control symbol at port n rate counting enable field 221 status field 219 corrupt packet at port n rate counting enable field 222 status field 220 count down value for interrupt rate control 154 CPPI 43 boundary diagram 50 rules for data traffic 43 RX operation 44 TX operation 51 CPU in Load/Store module data flow diagram 39 interrupts 85

requesting interrupt with INTERRUPT REQ field 159 CRC errors bad CRC in control symbol at port n rate counting enable field 221 status field 219 bad CRC in packet at port n rate counting enable field 222 status field 220 recovery suppression support field 186 CRC in control symbol 24 CRC in packet 23 credit for outbound packets 75 CRF\_SUPPORT field of PE\_FEAT 186 critical error interrupt to the CPU 85 critical request flow support field 186 CS\_EMB field of SPn\_CS\_TX 240 CTRL\_CAPT 217 cut-through mode option for port n 236

# D

DATA\_MESS field of DEST\_OP 189 DATA MESS field of SRC OP 188 data flow diagram for Load/Store module 39 data flow overview for SRIO peripheral 21 data message support for destination device 189 data message support for source device 188 data rate select field for SERDES receiver 126 DEBUG field of SPn\_CTL\_INDEP 236 debug mode selection for port n 237 debug packet field for port n 237 decode registers for interrupt conditions 150 decoding interrupt condition source 97 decrement rate for port error rate counter 228 de-emphasis field 128 DE field of SERDES\_CFGTXn\_CNTL 128 delimiting of control symbols 24 delineation error at port n rate counting enable field 222 status field 220 dest\_id field of TX buffer descriptor 52 DEST\_OP 189 DESTID field for LSUn 159 DESTID field of ID\_CAPT 216 DESTID field of LSUn\_REG4 159 destination IDs destination ID associated with logical/transport error 216 device ID for port-write target 218 disable base ID match requirement field for ports 231 for control flows description 181 introduction 66 for LSU transmission 159 size select field for flow control 181 destination operations CAR 189 DEV\_ID 182

### SRIO Registers

DEV INFO 183 DEVICE\_VENDORIDENTITY field of DEV\_ID 182 DEVICEID\_MSB field of PW\_TGT\_ID 218 DEVICEID\_REG1 121 DEVICEID\_REG2 122 device ID capture CSR for logical/transport errors 216 device identity CAR 182 DEVICEIDENTITY field of DEV ID 182 DEVICEID field of PW\_TGT\_ID 218 device IDs base device ID for host PE 194 base device ID for large common transport system 193 base device ID for small common transport system 193 device ID for port-write target 218 disable base ID match requirement field for ports 231 flow control destination ID size field 181 lower boundary for packet forwarding 8-bit IDs 124 16-bit IDs 123 node ID field to compare to incoming destination ID 122 node ID field to supply outgoing source ID 121 size selection field for LSUn 159 upper boundary for packet forwarding 8-bit IDs 124 16-bit IDs 123 device information CAR 183 device revision field 183 device type field 182 device wakeup after bootloading 80 differential signals/pins 25 direct I/O data path description 39 introduction 35 RX operation 42 TX operation 40 disable error checking for port n 207 disable port n 207 DISCOVERED field of SP GEN CTL 199 DISCOVERY\_TIMER field of SP\_IP\_DISCOVERY\_TIMER 230 DMA bus considerations regarding CPU interrupts 85 in data path description for LSUs 39 in direct I/O RX operation 42 in Load/Store module data flow diagram 39 in message passing 43 in SRIO component block diagram 26 DMA clock frequency as variable in clock prescaling 233 DMA error status bit for MAU 211 doorbell information field for LSUn 160 doorbell interrupt condition clear registers 133 doorbell interrupt condition routing registers 144

doorbell interrupt condition status registers 132 DOORBELLn\_ICCR 133 DOORBELLn\_ICRR 144 DOORBELLn\_ICRR2 144 DOORBELLn\_ICSR 132 doorbell operation 63 doorbell packets Ftype and Ttype 25 packet header 64 priority 64 used to cause CPU interrupts 85 doorbell-retry response during direct I/O reception 42 doorbell support for destination device 189 doorbell support for source device 188 DRBLL INFO field of LSUn REG5 160 drop packet enable for port n 207 DSP address field for LSUn 157

# Ε

EF\_ID field of ERR\_RPT\_BH 209 EF\_ID field of SP\_MB\_HEAD 196 EF\_PTR field of ERR\_RPT\_BH 209 EF\_PTR field of SP\_MB\_HEAD 196 emulation 74 EN\_STAT field of BLKn\_EN\_STAT 120 enable and enable status registers 71 enable bit(s) for access to read-only registers during boot loading 113 for adaptive equalizer 125 for entire SRIO peripheral 116 for fixed-phase transmit clocking 128 for flow control 112 for logical blocks 119 for port idle error checking 231 for port illegal-transfer error reporting 237 for port multicast-event interrupt 231 for port n 207 for port reset interrupt 232 for port self-reset interrupt 231 for port-write error reporting 231 for port-write-in interrupt 232 for SERDES PLLs 115, 131 for SERDES receivers 126 for SERDES transmitters 129 enable input only for port n 207 enable multicast-event participation for port n 207 enable output only for port n 207 enable status bit(s) for entire SRIO peripheral 117 for logical blocks 0 through 8 117, 120 endianness 68 EN field of BLKn\_EN 119 EN field of GBL\_EN 116 ENFTP field of SERDES\_CFGTXn\_CNTL 128 ENPLL1 field of PER\_SET\_CNTL 113

ENPLL2 field of PER SET CNTL 113 ENPLL3 field of PER\_SET\_CNTL 113 ENPLL4 field of PER\_SET\_CNTL 113 ENPLL field of SERDES\_CFGn\_CNTL 130 ENRX field of SERDES\_CFGRXn\_CNTL 125 ENTX field of SERDES\_CFGTXn\_CNTL 128 eop field of RX buffer descriptor 47 eop field of TX buffer descriptor 52 eog field of RX buffer descriptor 47 eog field of TX buffer descriptor 52 EQ field of SERDES\_CFGRXn\_CNTL 125 equalizer control field 125 ERR\_DET 210 ERR\_EN 212 ERR\_MSG\_FORMAT\_ENABLE field of ERR\_EN 212 ERR MSG FORMAT field of ERR DET 210 ERR\_RPT\_BH 209 ERR\_RST\_EVNT\_ICCR 143 ERR\_RST\_EVNT\_ICRR 149 ERR\_RST\_EVNT\_ICRR2 149 ERR\_RST\_EVNT\_ICRR3 149 ERR\_RST\_EVNT\_ICSR 142 ERROR CHECK DISABLE field of SPn CTL 206 ERROR\_RATE\_BIAS field of SPn\_ERR\_RATE 228 ERROR\_RATE\_COUNTER field of SPn\_ERR\_RATE 228 ERROR\_RATE\_DEGRADED\_THRESH field of SPn\_ERR\_THRESH 229 ERROR\_RATE\_FAILED\_THRESH field of SPn\_ERR\_THRESH 229 ERROR\_RATE\_RECOVERY field of SPn\_ERR\_RATE 228 ERROR\_TYPE field of SPn\_ERR\_ATTR\_CAPT\_DBG0 223 error checking for ports general error checking disable field 207 idle error checking disable field 231 error handling and logging for logical/transport errors 83 error rate counter for port n count value 228 decrement rate 228 peak count value 228 threshold 228 error rate counting enable register for port n 221 error rate thresholds for port n broken link case 229 degraded link case 229 error recovery software option for port n 236 error reporting block header register 209 error reporting thresholds for port n broken link case 229 degraded link case 229 error, reset, and special event interrupt condition clear register 143 error, reset, and special event interrupt condition routing registers 149 error, reset, and special event interrupt condition status

register 142 **ERROR** response during direct I/O reception 42 during message passing 43 error status interrupt to the CPU 85 error type field for port n error capture 223 EXTENDED\_ADDRESSING\_CONTROL field of PE\_LL\_CTL 190 EXTENDED\_ADDRESSING\_SUPPORT field of PE\_FEAT 186 EXTENDED\_FEATURES field of PE\_FEAT 186 extended address 2 MSBs field for LSUn 159 extended address LSB field for LSUn 156 extended address MSB field for LSUn 155 extended features ID field 196 EXTENDEDFEATURESPTR field of ASBLY\_INFO 185 extended feature support field 186 external device requirements 20

# F

features not supported in SRIO peripheral 20 features supported in SRIO peripheral 19 FIFOs in data path description for LSUs 39 in direct I/O RX operation 42 in direct I/O TX operation 40 in Load/Store module data flow diagram 39 in message passing 43 in SRIO peripheral block diagram 21 TX FIFO bypass field for ports 231 finding interrupt source with help from interrupt status decode registers 97 fixed transmit clock phase enable bit 128 FLOW\_CNTL\_ID field of FLOW\_CNTLn 181 FLOW CNTLn 181 FLOW\_CONTROL\_SUPPORT field of PE\_FEAT 186 FLOW\_MASK field of LSUn\_FLOW\_MASKS 162 flow control 65 flow control enable bit for data flow in logical layer of peripheral 112 for port n transmit flow control 236 flow control table entry register 181 flow masks for CPPI (message) transmission 169 for LSU transmission 162 introduction 67 force insertion of control symbol in outbound packet 240 force reinitialization process for port n 236 format type associated with logical/transport error 217 FREE field of PCR 112 free run bit 112 free run emulation mode 75 frequency points of 1x/4x LP-Serial specification 18 frequency prescaler select field 114 frequency range versus MPY value 30 FTYPE field of CTRL CAPT 217 Ftypes of SRIO packets 25

# G

GBL\_EN\_116 GBL\_EN\_STAT\_117 global enable bit\_116 global enable status bit\_118 global enabling/disabling of all logical blocks\_71

# Η

H\_ADDR\_CAPT 214 head descriptor pointer field for RX queue n 166 head descriptor pointer field for TX queue n 164 header fields doorbell operation 64 message request packet 44 hexadecimal notational convention 14 HOP\_COUNT field of LSUn\_REG5 160 host base device ID lock CSR 194 host device mode field 199

# I

ID CAPT 216 ID\_SIZE field of LSUn\_REG4 159 idle error checking disable field for ports 231 ILL\_TRANS\_EN field of SPn\_CTL\_INDEP 236 ILL TRANS ERR field of SPn CTL INDEP 236 illegal transaction at LSU, TXU, MAU, or RXU reporting enable field 212 status field 210 illegal transfer error at port n reporting enable field 237 status field 237 INBOUND\_ACKID field of SPn\_ACKID\_STAT 202 INFO\_TYPE field of SPn\_ERR\_ATTR\_CAPT\_DBG0 223 initialization example for message passing 61 initialization example for the SRIO peripheral 77 INITIALIZED\_PORT\_WIDTH field of SPn\_CTL 206 initialized status bit for ports 205 initialized width field for port n 206 in-order reception of message packets 49 in-order requirement bits for RX queues 173 INPUT\_ERROR\_ENC field of SPn\_ERR\_STAT 203 INPUT\_ERROR\_STP field of SPn\_ERR\_STAT 203 INPUT PORT ENABLE field of SPnCTL 206 INPUT\_RETRY\_STP field of SPn\_ERR\_STAT 203 input enable field for port n 207 input error-stopped status bit for ports 204 input retry-stopped status bit for ports 204 input termination field for SERDES receiver 126 input transmission error status bit for ports 204 INTDSTn\_DECODE 150 INTDSTn RATE CNTL 154 interconnect architecture for RapidIO 18 interfacing two 1x or 4x devices 18 INTERRUPT\_REQ field of LSUn\_REG4 159 interrupt approach to messaging protocol 86

interrupt condition clearing 86 interrupt condition clear registers for CPPI interrupt conditions 135, 137 for doorbell interrupt conditions 133 for error, reset, and special event (port) interrupt conditions 143 for LSU interrupt conditions 141 interrupt condition routing 93 interrupt conditions 85 interrupt condition status checking 86 interrupt condition status registers for CPPI interrupt conditions 134, 136 for doorbell interrupt conditions 132 for error, reset, and special event (port) interrupt conditions 142 interrupt destinations controlling interrupt pacing with interrupt rate control registers 99 narrowing down interrupt sources with help from interrupt status decode registers 97 selecting with interrupt condition routing registers 93 interrupt error at port n reporting enable field 237 status field 237 interrupt generation 99 interrupt handling 100 interrupt pacing (rate control) 99 interrupt rate control registers 154 interrupt request field for LSUn 159 interrupt status decode registers description 150 introduction 97 mapping example 98 invert polarity bit for SERDES receiver 126 invert polarity bit for SERDES transmitter 128 INVPAIR field of SERDES CFGRXn CNTL 125 INVPAIR field of SERDES\_CFGTXn\_CNTL 128 I/O error response at LSU reporting enable field 212 status field 210 IP\_PRESCAL 233 IRQ\_EN field of SPn\_CTL\_INDEP 236 IRQ ERR field of SPn CTL INDEP 236

# L

L2 memory in Load/Store module data flow diagram 39 lane select field for port n 206 large common transport system base device ID 193 large common transport system support field 186 LB field of SERDES\_CFGn\_CNTL 130 LCL\_CFG\_BAR 192 LCL\_CFG\_HBAR 191 LETTER\_MASK field of RXU\_MAP\_Ln 178 LETTER field of RXU\_MAP\_Ln 178 letter number associated with logical/transport error 217 letter number masking 45 letters and mailboxes 43 limiting which devices can access a mailbox 45 line rate versus PLL output clock frequency 29 LINK\_STATUS field of SPn\_LM\_RESP 201 LINK\_TIMEOUT\_EN field of SPn\_RATE\_EN 221 LINK\_TIMEOUT field of SPn\_ERR\_DET 219 link maintenance command field for port n 240 link-request control symbol generation register 200 link responses acknowledge or link-response control symbol overdue at port n rate counting enable field 222 status field 220 link-response valid field 201 link status received 201 non-outstanding ackID at port n rate counting enable field 222 status field 220 link timeout at port n rate counting enable field 222 status field 220 Little Endian versus Big Endian 68 Load/Store module data flow diagram 39 data path description 39 enable bit 119 enable status bits 117, 120 power down state 43 Load/Store units. See LSUs 40 local configuration space base address CSRs 191, 192 lockout field for port n 207 logical blocks of the SRIO peripheral 71 logical layer content in SRIO data stream 22 definition 16 logical layer buffers in packet transmission discussion 75 in SRIO component block diagram 26 logical/transport error handling and logging 83 logical/transport layer address capture CSR 215 logical/transport layer control capture CSR 217 logical/transport layer device ID capture CSR 216 logical/transport layer error detect CSR 210 logical/transport layer error enable CSR 212 logical/transport layer high address capture CSR 214 LOG. See logical layer 23 loopback mode 113 loop bandwidth field for SERDES PLL 130 LOS field of SERDES\_CFGRXn\_CNTL 125 loss of signal detection in SERDES receiver 126 LSBs of address associated with logical/transport error 215 LSBs of destination ID associated with logical/transport error 216 LSBs of source ID associated with logical/transport error 216 LSU\_ICCR 141 LSU\_ICRR0 to LSU\_ICRR3 147

LSU ICSR 138 LSU congestion control flow mask register 162 LSU control register 0 155 LSU control register 1 156 LSU control register 2 157 LSU control register 3 158 LSU control register 4 159 LSU control register 5 160 LSU control register 6 161 LSU interrupt condition clear register 141 LSU interrupt condition routing registers 147 LSU interrupt condition status register 138 LSUn\_FLOW\_MASKS 162 LSUn\_REG0 155 LSUn\_REG1 156 LSUn REG2 157 LSUn\_REG3 158 LSUn\_REG4 159 LSUn\_REG5 160 LSUn\_REG6 161 LSUs data path description 39 enable bit 119 enable status bits 117, 120 handling of unavailable outbound credit 76 in Load/Store module data flow diagram 39 in SRIO component block diagram 26 register introduction 35 register-load timing diagram 37 register programming example 38 RX operation 42 TX operation 40

# Μ

MAILBOX\_MASK field of RXU\_MAP\_Ln 178 mailboxes and letters 43 mailbox field of RX buffer descriptor 47 MAILBOX field of RXU\_MAP\_Ln 178 mailbox field of TX buffer descriptor 52 mailbox number associated with logical/transport error 217 mailbox number masking 45 mailbox to queue mapping during message reception introduction 44 register descriptions 177 maintenance packets Ftypes and Ttypes 25 introduction 63 masking mailbox and letter numbers 45 master device mode field 199 MAU enable bit 119 enable status bits 117, 120 handling of unavailable outbound credit 76 in SRIO component block diagram 26 MAX\_RETRY\_EN field of SPn\_CTL\_INDEP 236

MAX RETRY ERR field of SPn CTL INDEP 236 MAX\_RETRY\_THR field of SPn\_CTL\_INDEP 236 maximum packet size exceeded at port n rate counting enable field 222 status field 220 maximum retry error at port n reporting enable field 237 reporting threshold field 237 status field 237 memory access unit. See MAU 26 MEMORY field of PE\_FEAT 186 memory-mapped registers enable bit 119 memory-mapped registers enable status bits 118, 120 memory present field 186 message\_length field of RX buffer descriptor 47 message length field of TX buffer descriptor 52 message error response at TXU reporting enable field 212 status field 210 message format error at RXU reporting enable field 212 status field 210 message packet Ftype and Ttype 25 message passing 43 CPPI reset and power down state 59 ERROR response 43 initialization example 61 interrupting the CPU after reception 86 order of received packets 49 order of response packets during TX operation 58 order of transmitted packets 54 responses to CPPI transmissions 58 RETRY response 43 RX buffer descriptor fields 47 RX buffer descriptor link-list figure 61 RX descriptor pointers 46 RX operation 44 software requirements 60 teardown of RX buffer descriptor queues 50 time-out condition during RX operation 47 time-out condition during TX operation 59 TX buffer descriptor fields 52 TX buffer descriptor link-list figure 62 TX descriptor pointers 51 TX operation 51 weighted round-robin transmission scheme 54 message request packet header fields 44 message request timeout at RXU reporting enable field 212 status field 211 message segment associated with logical/transport error 217 message support for destination device 189 message support for source device 188 MLTC\_EN field of SP\_IP\_MODE 231 MLTC\_IRQ field of SP\_IP\_MODE 231

MMRs enable bit 119 MMRs enable status bits 118, 120 mode selection field for ports 231 MPY field of SERDES\_CFGn\_CNTL 130 MPY value versus frequency range 30 MSB\_DESTID field of ID\_CAPT 216 MSB\_SOURCEID field of ID\_CAPT 216 MSBs of address associated with logical/transport error 214 MSBs of destination ID associated with logical/transport error 216 MSBs of source ID associated with logical/transport error 216 MSG\_ERR\_RESP\_ENABLE field of ERR\_EN 212 MSG ERR RSPNS field of ERR DET 210 MSG\_REQ\_TIMEOUT\_ENABLE field of ERR\_EN 212 MSG\_REQ\_TIMEOUT field of ERR\_DET 210 MSGINFO field of CTRL\_CAPT 217 MULT\_EVNT\_CS field of SPn\_MULT\_EVNT\_CS 239 MULTICAST\_PARTICIPANT field of SPn\_CTL 206 multicast-event control symbol request field for port n 239 multicast-event interrupt enable field for ports 231 multicast-event interrupt status field for ports 231 multicast-event participant enable field for port n 207 multiple ports with 1x operation 75 multiply field for SERDES PLL 131

# Ν

next\_descriptor\_pointer field of RX buffer descriptor 47 next\_descriptor\_pointer field of TX buffer descriptor 52 next expected acknowledge ID field 202 next transmitted acknowledge ID field 202 node ID field to compare to incoming destination ID 122 to supply outgoing source ID 121 NON\_OUTSTANDING\_ACKID\_EN field of SPn\_RATE\_EN 221 NON\_OUTSTANDING\_ACKID field of SPn\_ERR\_DET 219 non-posted WRITE operations during direct I/O transmission 41 normal mode selection for port n 237 notational conventions 14 NREAD packet Ftype and Ttype 25 number of data bytes field for LSUn 158 Number of Msgs fields of TX QUEUE CNTLn 174 NWRITE\_R packet Ftype and Ttype 25 NWRITE packet Ftype and Ttype 25

# 0

OK status bit for ports 205 operating rate field for SERDES receiver 126 for SERDES transmitter 128 operation sequence for SRIO packets 22 OUT\_BOUND\_ PORT field of PF\_8B\_CNTL 124 OUTBOUND ACKID field of SPn ACKID STAT 202 outbound credit 75 outbound port number for packet forwarding 124 out-of-order reception of message packets 49 out-of-order responses during message-passing TX operation 58 OUTPORTID field of LSUn REG4 159 OUTPUT\_DEGRD\_ENC field of SPn\_ERR\_STAT 203 OUTPUT\_ERROR\_ENC field of SPn\_ERR\_STAT 203 OUTPUT\_ERROR\_STP field of SPn\_ERR\_STAT 203 OUTPUT FLD ENC field of SPn ERR STAT 203 OUTPUT\_PKT\_DROP field of SPn\_ERR\_STAT 203 OUTPUT\_PORT\_ENABLE field of SPn\_CTL 206 OUTPUT\_RETRIED field of SPn\_ERR\_STAT 203 OUTPUT\_RETRY\_ENC field of SPn\_ERR\_STAT 203 OUTPUT\_RETRY\_STP field of SPn\_ERR\_STAT 203 output amplitude field 128 output degraded status bit for ports 203 output enable field for port n 207 output error-stopped status bit for ports 204 output failed status bit for ports 203 output packet drop status bit for ports 203 output port number field for LSUn 159 output retry control symbol status bit for ports 204 output retry status bit for ports 204 output retry-stopped status bit for ports 204 output swing field 128 output transmission error status bit for ports 204 OUTSTANDING\_ACKID field of SPn\_ACKID\_STAT 202 override memory sleep bit 113 oversize packet at port n rate counting enable field 222 status field 220 ownership field of RX buffer descriptor 47 ownership field of TX buffer descriptor 52

# Ρ

PACKET\_TYPE field of LSUn\_REG5 160 packet drop status bit for ports 203 packet forwarding registers 8-bit device IDs 124 16-bit device IDs 123 packet header capture fields for port n error capture bytes 0 to 3 224 bytes 4 to 7 225 bytes 8 to 11 226 bytes 12 to 15 227 packet header fields direct I/O operation 38 doorbell operation 64 message request packet 44 packet-not-accepted control symbol at port n rate counting enable field 221 status field 220 packet priority field for LSUn 159 packet reordering during transmission 75

packet response timeout at LSU or TXU reporting enable field 213 status field 211 packets bad CRC in packet at port n rate counting enable field 222 status field 220 force insertion of control symbol in outbound packet 240 Ftype and Ttype 25 maintenance packets 63 operation sequence 22 oversize packet at port n rate counting enable field 222 status field 220 send debug packet field for port n 237 streaming-write example 23 unexpected ackID in packet at port n rate counting enable field 222 status field 220 unexpected packet at port n rate counting enable field 222 status field 220 PAR\_0 field of SPn\_CS\_TX 240 PAR\_1 field of SPn\_CS\_TX 240 parameter0 control symbol field for port n 240 parameter1 control symbol field for port n 240 payload capture fields for port-write-in 234 PCR 112 PE\_FEAT 186 PE LL CTL 190 peak value of error rate counter for port n 228 PER\_SET\_CNTL 113 PEREN field of PCR 112 peripheral class field 111 peripheral control register 112 peripheral data flow 21 peripheral flow control enable bit 112 peripheral global enable register 116 peripheral global enable status register 117 peripheral identification register 111 peripheral revision field 111 peripheral settings control register 113 peripheral type field 111 PF\_8B\_CNTL 124 PF 16B CNTLn 123 PHY. See physical layer 23 physical layer content in SRIO data stream 22 control symbols 24 definition 16 in Load/Store module data flow diagram 39 specifications 18 Physical Layer 1x/4x LP-Serial specification 18 physical layer buffers in packet transmission discussion 75

in SRIO component block diagram 26 PID register 111 pins/differential signals 25 PKT\_RESP\_TIMEOUT\_ENABLE field of ERR\_EN 212 PKT\_RSPNS\_TIMEOUT field of ERR\_DET 210 PKT\_UNEXPECTED\_ACKID\_EN field of SPn\_RATE\_EN 221 PKT\_UNEXPECTED\_ACKID field of SPn\_ERR\_DET 219 PLL block for SERDES 21, 28 PLL enable bit 131 PLL multiply field for SERDES macro 131 PLL output clock frequency versus line rate 29 pointer to the next block in the data structure 196 polarity inversion bit for RIORX and RIORX (reception) 126 for RIOTX and RIOTX (transmission) 128 port 0 enable status bit 117 port 1 enable status bits 117 port 2 enable status bits 117 port 3 enable status bits 117 PORT\_DISABLE field of SPn\_CTL 206 PORT\_ERROR field of SPn\_ERR\_STAT 203 PORT\_ID field of SPn\_RST\_OPT 235 port\_id field of TX buffer descriptor 52 PORT LOCKOUT field of SPn CTL 206 PORT OK field of SPn ERR STAT 203 PORT\_TYPE field of SPn\_CTL 206 PORT\_UNINITIALIZED field of SPn\_ERR\_STAT 203 PORT\_WIDTH\_OVERRIDE field of SPn\_CTL 206 PORT\_WIDTH field of SPn\_CTL 206 PORT\_WRITE\_PND field of SPn\_ERR\_STAT 203 PORT\_WRITE field of DEST\_OP 189 PORT WRITE field of SRC OP 188 port attributes error capture CSR 0 223 port control CSR 206 port control independent register 236 port control symbol transmit registers 240 port error and status CSR 203 port error capture CSR 1 224 port error capture CSR 2 225 port error capture CSR 3 226 port error capture CSR 4 227 port error detect CSR 219 port error rate CSR 228 port error rate enable CSR 221 port error rate threshold CSR 229 port general control CSR 199 port ID field for port-write request at port n 235 port IP discovery timer for 4x mode register 230 port IP mode CSR 231 port IP prescaler register 233 port link maintenance request CSR 200 port link maintenance response CSR 201 port link time-out control CSR 197 port local ackID status CSR 202

PROMISCUOUS field of RXU\_MAP\_Hn description 178 introduction 45 PROTOCOL\_ERROR\_EN field of SPn\_RATE\_EN 221 PROTOCOL\_ERROR field of SPn\_ERR\_DET 219 PW\_CAPT0 field of SP\_IP\_PW\_IN\_CAPT0 234 PW\_CAPT1 field of SP\_IP\_PW\_IN\_CAPT1 234 PW\_CAPT2 field of SP\_IP\_PW\_IN\_CAPT2 234 PW\_CAPT3 field of SP\_IP\_PW\_IN\_CAPT3 234

port multicast-event control symbol request registers

239

ports

41

power down state

CPPI module 59

Load/Store module 43

port n error capture

control information field 224

type of information field 223

valid information field 223

type of error field 223

port reset option CSR 235

enable status bits 120

port silence timer registers 238

port-write-in capture CSR 234

port-write-in capture payload 234

port-write-in interrupt enable field 232

port-write-in interrupt status field 232

port-write maintenance operation 63

port-write target device ID CSR 218

PRESCALE field of IP\_PRESCAL 233

priority arbiter for single-port transmission 76

processing element logical layer control CSR 190

pri field of RX buffer descriptor 47

pri field of TX buffer descriptor 52

priority of doorbell packets 64

processor present field 186

PRIORITY field of LSUn\_REG4 159

priority transmit credit thresholds 113

processing element features CAR 186

PROCESSOR field of PE FEAT 186

port-write pending status field 204

port-write repeat period field 230

port-write request port ID 235

enable bits 119

packet header bytes 0 to 3 field 224

packet header bytes 4 to 7 field 225

packet header bytes 8 to 11 field 226

port response time-out control CSR 198

in SRIO component block diagram 26

port-write error reporting disable field 231

port-write generation support for destination device 189

posted WRITE operations during direct I/O transmission

PRESCALER\_SELECT field of PER\_SET\_CNTL 113

port-write generation support for source device 188

packet header bytes 12 to 15 field 227

PW\_DIS field of SP\_IP\_MODE 231 PW\_EN field of SP\_IP\_MODE 231 PW\_IRQ field of SP\_IP\_MODE 231 PW\_TGT\_ID 218 PW\_TIMER field of SP\_IP\_DISCOVERY\_TIMER 230

# Q

QUEUE\_ID field of RXU\_MAP\_Hn 178 QUEUEn\_FLOW\_MASK fields of TX\_CPPI\_FLOW\_MASKS[0-7] 169 QUEUEn\_IN\_ORDER fields of RX\_CPPI\_CNTL 173 QUEUEn RXDMA CP 167 QUEUEn RXDMA HDP 166 QUEUEn TEAR DWN fields of RX\_QUEUE\_TEAR\_DOWN 172 QUEUEn TEAR DWN fields of TX\_QUEUE\_TEAR\_DOWN 168 QUEUEn TXDMA CP 165 QUEUEn\_TXDMA\_HDP 164 queue n receive DMA completion pointer register 167 queue n receive DMA head descriptor pointer register 166 queue n transmit DMA completion pointer register 165 queue n transmit DMA head descriptor pointer register 164 Queue Pointer fields of TX\_QUEUE\_CNTLn 174 queue teardown bits for message reception 172 queue teardown bits for message transmission 168 queue transmission order 54

# R

RapidIO architectural hierarchy 16 external device requirements 20 features 16 features supported in SRIO peripheral 19 interconnect architecture 18 standards 20 RapidIO DEVICEID1 register 121 RapidIO DEVICEID2 register 122 **RATE** fields effect on data rate 30 RATE field of SERDES\_CFGRXn\_CNTL 125 RATE field of SERDES CFGTXn CNTL 128 rate select field for SERDES receiver 126 rate select field for SERDES transmitter 128 RCVD\_PKT\_NOT\_ACCPT field of SPn\_ERR\_DET 219 RCVD\_PKT\_OVER\_276B field of SPn\_ERR\_DET 219 RCVD\_PKT\_WITH\_BAD\_CRC field of SPn\_ERR\_DET 219 RCVED\_PKT\_NOT\_ACCPT\_EN field of SPn\_RATE\_EN 221 RCVED PKT OVER 276B EN field of SPn RATE EN 221 RCVED PKT WITH BAD CRC EN field of SPn\_RATE\_EN 221 READ field of DEST\_OP 189 READ field of SRC OP 188

read support for destination device 189 read support for source device 188 READ transactions during direct I/O transmission 41 receive CPPI control register 173 receive CPPI interrupt condition clear register 135 receive CPPI interrupt condition routing registers 145 receive CPPI interrupt condition status register 134 receive queue teardown register 172 receiver enabling for SERDES macro introduction 30 receiver enable bit 126 receive/transmit lockout field for port n 207 register configuration offset field for LSUn 156 register introduction 102 reinitialization process field for port n 236 related documentation 14 reordering of outbound packets 75 reporting thresholds for port n errors broken link case 229 degraded link case 229 request packets Ftypes and Ttypes 25 in SRIO operation sequence 22 requirements for external devices 20 reset and power down 70 CPPI module 59 enable and enable status registers 71 Load/Store module 43 software shutdown details 74 reset interrupt enable field for ports 232 reset interrupt status field for ports 232 reset option CSR for port n 235 RESPONSE\_VALID field of SPn\_LM\_RESP 201 response packets Ftypes and Ttypes 25 in SRIO operation sequence 22 responses to CPPI (message) transmissions 58 response time-out error at LSU or TXU reporting enable field 213 status field 211 response timer in direct I/O reception 42 in Load/Store module data flow diagram 39 in message reception 47 in message transmission 59 RETRANSMIT SUPPRESS field of PE FEAT 186 retry\_count field of TX buffer descriptor 52 RETRY response in message passing 43 REV field of PID 111 RIOCLK and RIOCLK signals 25 RIORXn and RIORXn signals 25 RIOTXn and RIOTXn signals 25 round-robin access to TX buffer descriptor queues 54 routing interrupt conditions to interrupt destinations 93 routing registers for CPPI interrupt conditions 145, 146

for doorbell interrupt conditions 144 for error, reset, and special event (port) interrupt conditions 149 for LSU interrupt conditions 147 RST\_CS field of SP\_IP\_MODE 231 RST\_EN field of SP\_IP\_MODE 231 rules for CPPI data traffic 43 RX\_CP field of QUEUEn\_RXDMA\_CP 167 RX\_CPPI\_CNTL 173 RX\_CPPI\_ICCR 135 RX\_CPPI\_ICRR 145 RX\_CPPI\_ICRR2 145 RX\_CPPI\_ICSR 134 RX\_CPPI\_SECURITY\_ENABLE field of ERR\_EN 212 RX CPPI SECURITY field of ERR DET 210 RX\_HDP field of QUEUEn\_RXDMA\_HDP 166 RX IO DMA ACCESS field of ERR DET 210 RX\_IO\_SECURITY\_ENABLE field of ERR\_EN 212 RX\_QUEUE\_TEAR\_DOWN 172 RX buffer descriptor fields 47 RX buffer descriptor link-list figure 61 RX buffer descriptor queue teardown 50 **RX CPPI security error** reporting enable field 213 status bit 211 RX I/O DMA access error reporting enable field 213 status field 211 RX shared buffer in direct I/O RX operation 42 in direct I/O TX READ transaction 41 in SRIO component block diagram 26 RXU enable bit 119 enable status bits 117, 120 handling of unavailable outbound credit 76 in SRIO component block diagram 26 **RXU MAP registers** description 177 introduction 45

# S

security error reporting enable bit for MAU 213 security error reporting enable bit for RXU 213 security error status bit for MAU 211 security error status bit for RXU 211 SEGMENT\_MAPPING field of RXU\_MAP\_Hn 178 segmentation of outbound direct I/O requests 42 SELF\_RST field of SP\_IP\_MODE 231 self reset interrupt enable field for ports 231 SEND\_DBG\_PKT field of SPn\_CTL\_INDEP 236 send debug packet field for port n 237 SERDES\_CFGn\_CNTL 130 SERDES\_CFGRXn\_CNTL 125 SERDES\_CFGTXn\_CNTL 128 SERDES macro configuration register 130 SERDES macros configuration example 35 description 28 enable bits 115 in SRIO component block diagram 26 in SRIO peripheral block diagram 21 PLL enabling 28 receiver enabling 30 transmitter enabling 33 SERDES receive channel configuration registers 125 SERDES transmit channel configuration registers 128 serialization/deserialization (SERDES) 21 serial port IP prescaler register 233 Serial RapidIO peripheral. See SRIO peripheral 19 shared buffers in direct I/O RX operation 42 in direct I/O TX READ transaction 41 in direct I/O TX WRITE transaction 40 in Load/Store module data flow diagram 39 in message passing 43 in SRIO component block diagram 26 SILENCE\_TIMER field of SPn\_SILENCE\_TIMER 238 silent state period for port n 238 single-/multi-segment selection field for message reception 180 single port with 1x or 4x operation 76 small common transport system base device ID 193 SOFT\_REC field of SPn\_CTL\_INDEP 236 SOFT field of PCR 112 soft stop bit 112 soft stop emulation mode 75 software memory sleep override bit 113 software requirements for message passing 60 software shutdown details 74 sop field of RX buffer descriptor 47 sop field of TX buffer descriptor 52 source address field for LSUn 157 source ID associated with logical/transport error 216 source ID check or ignore field for message reception 180 SOURCEID field of ID\_CAPT 216 SOURCEID field of RXU MAP Ln 178 source operations CAR 188 SP\_GEN\_CTL 199 SP\_IP\_DISCOVERY\_TIMER 230 SP IP IPW IN CAPTn 234 SP\_IP\_MODE 231 SP\_LT\_CTL 197 SP\_MB\_HEAD 196 SP\_MODE field of SP\_IP\_MODE 231 SP\_RT\_CTL 198 SPn\_ACKID\_STAT 202 SPn\_CS\_TX 240 SPn\_CTL 206 SPn\_CTL\_INDEP 236 SPn\_ERR\_ATTR\_CAPT\_DBG0 223

SPn ERR CAPT DBG1 224 SPn\_ERR\_CAPT\_DBG2 225 SPn\_ERR\_CAPT\_DBG3 226 SPn\_ERR\_CAPT\_DBG4 227 SPn\_ERR\_DET 219 SPn\_ERR\_RATE 228 SPn\_ERR\_STAT 203 SPn ERR THRESH 229 SPn\_LM\_REQ 200 SPn\_LM\_RESP 201 SPn\_MULT\_EVNT\_CS 239 SPn RATE EN 221 SPn\_RST\_OPT 235 SPn\_SILENCE\_TIMER 238 src\_id field of RX buffer descriptor 47 SRC OP 188 SRIO peripheral component block diagram 26 data flow overview 21 emulation halt behavior 74 initialization example 77 packets 22 packet types 25 peripheral block diagram 21 pins/differential signals 25 RapidIO features not supported 20 RapidIO features supported 19 reset and power down 70 ssize field of TX buffer descriptor 52 status bits for recording interrupt conditions 86 status registers for CPPI interrupt conditions 134, 136 for doorbell interrupt conditions 132 for error, reset, and special event (port) interrupt conditions 142 for LSU interrupt conditions 138 STOP\_PORT\_FLD\_ENC\_ENABLE field of SPn\_CTL 206 stop on output failure at port n 207 stop receiving messages and reclaim buffers (RX teardown) 50 stop transmitting messages and clear buffers (TX teardown) 59 store-and-forward mode option for port n 236 STREAM\_WRITE field of DEST\_OP 189 STREAM\_WRITE field of SRC\_OP 188 streaming-write packet example 23 streaming-write support for destination device 189 streaming-write support for source device 188 stype0 and stype1 control symbols 24 stype0 control symbol field for port n 240 stype1 control symbol field for port n 240 STYPE\_0 field of SPn\_CS\_TX 240 STYPE\_1 field of SPn\_CS\_TX 240 suppression support field 186 SW\_MEM\_SLEEP\_OVERRIDE field of PER\_SET\_CNTL 113

SWING field of SERDES\_CFGTXn\_CNTL 128 switch capability field 186 SWITCH field of PE\_FEAT 186 SWRITE packet Ftype and Ttype 25 symbol alignment field 126

# Т

target IDs. See destination IDs 218 teardown\_complete field of RX buffer descriptor 47 teardown\_complete field of TX buffer descriptor 52 teardown bits for RX queues 172 teardown bits for TX queues 168 teardown of RX buffer descriptor queues 50 teardown of TX buffer descriptor queues 59 TERM field of SERDES\_CFGRXn\_CNTL 125 test and swap. See Atomic operations 25 TGT\_ID\_DIS field of SP\_IP\_MODE 231 thresholds for loss of signal detection (LOS field) 126 for port error rate counter 228 for priority 0, 1, and 2 transmit credit 113 for reporting errors broken link 229 degraded link 229 maximum retry error at port n 237 TIMEOUT\_VALUE field of SP\_LT\_CTL 197 TIMEOUT\_VALUE field of SP\_RT\_CTL 198 time-out condition during direct I/O reception 42 during message-passing RX operation 47 during message-passing TX operation 59 time-out values for ports link time-out 197 response time-out 198 trademarks 14 TRANS\_MODE field of SPn\_CTL\_INDEP 236 transaction priority field 114 transaction type associated with logical/transport error 217 transfer mode field for port n 236 transfer type field for flow control destination IDs 181 transmission error count for port n 228 transmission error recovery software option for port n 236 transmission flow control 65 transmit CPPI interrupt condition clear register 137 transmit CPPI interrupt condition routing registers 146 transmit CPPI interrupt condition status register 136 transmit CPPI supported flow mask registers 169 transmit CPPI weighted round robin control registers 174 transmit credit threshold for priorities 0 through 2 113 transmit data rate select field 128 transmit FIFO bypass field for ports 231 transmit flow control enable field for port n 236 transmit queue teardown register 168 transmit/receive lockout field for port n 207

transmitter enabling for SERDES macro introduction 33 transmitter enable bit 129 transport error handling and logging 83 transport layer content in SRIO data stream 22 definition 16 in Load/Store module data flow diagram 39 transport type field for message reception 179 TRA. See transport layer 23 TT field of FLOW\_CNTLn 181 tt field of RX buffer descriptor 47 TT field of RXU\_MAP\_Hn 178 tt field of TX buffer descriptor 52 TTYPE field of CTRL CAPT 217 Ttypes of SRIO packets 25 TX\_CP field of QUEUEn\_TXDMA\_CP 165 TX\_CPPI\_FLOW\_MASKS[0-7] 169 TX\_CPPI\_ICCR 137 TX\_CPPI\_ICRR 146 TX\_CPPI\_ICRR2 146 TX\_CPPI\_ICSR 136 TX FIFO BYPASS field of SP IP MODE 231 TX\_FLW field of SPn\_CTL\_INDEP 236 TX\_HDP field of QUEUEn\_TXDMA\_HDP 164 TX\_PRIn\_WM fields of PER\_SET\_CNTL 113 TX\_QUEUE\_CNTL[0-3] 174 TX\_QUEUE\_TEAR\_DOWN 168 TX buffer descriptor fields 52 TX buffer descriptor link-list figure 62 TX buffer descriptor queue teardown 59 TX buffers, credit, and packet re-ordering 75 TX shared buffer in direct I/O TX WRITE transaction 40 in SRIO component block diagram 26 TXU enable bit 119 enable status bits 117, 120 handling of unavailable outbound credit 76 in SRIO component block diagram 26 type field for port n 208 TYPE field of PID 111 type of error field for port n error capture 223 type of information field for port n error capture 223

# U

UDI definition 40 in Load/Store module data flow diagram 39 in SRIO component block diagram 26 UDI buffering setup field 114 unacknowledged ackID status field 202 unavailable outbound credit 76 undefined Ftypes 25 unexpected ackID in control symbol at port n rate counting enable field 221

status field 219 unexpected ackID in packet at port n rate counting enable field 222 status field 220 unexpected acknowledge control symbol at port n rate counting enable field 222 status field 220 unexpected control symbol at port n rate counting enable field 222 status field 220 unexpected packet at port n rate counting enable field 222 status field 220 uninitialized status bit for ports 205 unrecoverable error status bit for ports 204 UNSOLICITED\_ACK\_CNTL\_SYM\_EN field of SPn\_RATE\_EN 221 UNSOLICITED ACK CNTL SYM field of SPn\_ERR\_DET 219 UNSOLICITED\_RESP\_ENABLE field of ERR\_EN 212 UNSOLICITED\_RSPNS field of ERR\_DET 210 unsolicited response at LSU or TXU reporting enable field 213 status field 211 UNSUPPORTED\_TRANS\_ENABLE field of ERR\_EN 212 UNSUPPORTED\_TRANS field of ERR\_DET 210 unsupported transaction at MAU reporting enable field 213 status field 211 User Defined Interface. See UDI 40

# V

valid information field for port n error capture 223

# W

weighted round-robin access to TX buffer descriptor queues 54 weighted round robin control registers 174 width field for port n 206 width override field for port n 207 WRITE\_WITH\_RESP field of DEST\_OP 189 WRITE WITH RESP field of SRC OP 188 WRITE field of DEST OP 189 WRITE field of SRC\_OP 188 write support for destination device 189 write support for source device 188 WRITE transactions during direct I/O transmission description 40 non-posted 41 posted 41 write-with-response support for destination device 189 write-with-response support for source device 188

# Х

XAMSB field of LSUn\_REG4 159 XAMSBS field of ADDR\_CAPT 215 Xoff 65

Xon 65

### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

| Products           |                        | Applications       |                           |
|--------------------|------------------------|--------------------|---------------------------|
| Amplifiers         | amplifier.ti.com       | Audio              | www.ti.com/audio          |
| Data Converters    | dataconverter.ti.com   | Automotive         | www.ti.com/automotive     |
| DSP                | dsp.ti.com             | Broadband          | www.ti.com/broadband      |
| Interface          | interface.ti.com       | Digital Control    | www.ti.com/digitalcontrol |
| Logic              | logic.ti.com           | Military           | www.ti.com/military       |
| Power Mgmt         | power.ti.com           | Optical Networking | www.ti.com/opticalnetwork |
| Microcontrollers   | microcontroller.ti.com | Security           | www.ti.com/security       |
| Low Power Wireless | www.ti.com/lpw         | Telephony          | www.ti.com/telephony      |
|                    |                        | Video & Imaging    | www.ti.com/video          |
|                    |                        | Wireless           | www.ti.com/wireless       |

Mailing Address:

Texas Instruments

Post Office Box 655303 Dallas, Texas 75265

Copyright © 2006, Texas Instruments Incorporated